ReactOS 0.4.16-dev-329-g9223134
usetup.c File Reference
#include <usetup.h>
#include <math.h>
#include <ntstrsafe.h>
#include "cmdcons.h"
#include "devinst.h"
#include "fmtchk.h"
#include <debug.h>
Include dependency graph for usetup.c:

Go to the source code of this file.

Classes

struct  _FSVOL_CONTEXT
 
struct  _COPYCONTEXT
 

Macros

#define NDEBUG
 
#define InstallVolume   (InstallPartition->Volume)
 
#define SystemVolume   (SystemPartition->Volume)
 
#define VOLUME_NEW_AUTOCREATE   0x80
 
#define PARTITION_SIZE_INPUT_FIELD_LENGTH   9
 
#define PARTITION_MAXSIZE   (pow(10, (PARTITION_SIZE_INPUT_FIELD_LENGTH - 1)) - 1)
 

Typedefs

typedef struct _FSVOL_CONTEXT FSVOL_CONTEXT
 
typedef struct _FSVOL_CONTEXTPFSVOL_CONTEXT
 
typedef struct _COPYCONTEXT COPYCONTEXT
 
typedef struct _COPYCONTEXTPCOPYCONTEXT
 

Enumerations

enum  { PartTypeData , PartTypeExtended }
 

Functions

static VOID PrintString (IN PCSTR fmt,...)
 
static VOID DrawBox (IN SHORT xLeft, IN SHORT yTop, IN SHORT Width, IN SHORT Height)
 
VOID PopupError (PCCH Text, PCCH Status, PINPUT_RECORD Ir, ULONG WaitEvent)
 
static BOOL ConfirmQuit (PINPUT_RECORD Ir)
 
static VOID UpdateKBLayout (VOID)
 
static NTSTATUS NTAPI GetSettingDescription (IN PGENERIC_LIST_ENTRY Entry, OUT PSTR Buffer, IN SIZE_T cchBufferSize)
 
static NTSTATUS NTAPI GetNTOSInstallationName (IN PGENERIC_LIST_ENTRY Entry, OUT PSTR Buffer, IN SIZE_T cchBufferSize)
 
static VOID __cdecl USetupErrorRoutine (IN PUSETUP_DATA pSetupData,...)
 
static PAGE_NUMBER SetupStartPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER LanguagePage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER WelcomePage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER LicensePage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER RepairIntroPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER UpgradeRepairPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER InstallIntroPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER DeviceSettingsPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER HandleGenericList (PGENERIC_LIST_UI ListUi, PAGE_NUMBER nextPage, PINPUT_RECORD Ir)
 
static PAGE_NUMBER ComputerSettingsPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER DisplaySettingsPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER KeyboardSettingsPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER LayoutSettingsPage (PINPUT_RECORD Ir)
 
static BOOLEAN IsMediumLargeEnough (_In_ ULONGLONG SizeInBytes)
 
static PAGE_NUMBER SelectPartitionPage (PINPUT_RECORD Ir)
 
static VOID ShowPartitionSizeInputBox (SHORT Left, SHORT Top, SHORT Right, SHORT Bottom, ULONG MaxSize, PWSTR InputBuffer, PBOOLEAN Quit, PBOOLEAN Cancel)
 
static PAGE_NUMBER CreatePartitionPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER ConfirmDeleteSystemPartitionPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER DeletePartitionPage (PINPUT_RECORD Ir)
 
static FSVOL_OP CALLBACK FsVolCallback (_In_opt_ PVOID Context, _In_ FSVOLNOTIFY FormatStatus, _In_ ULONG_PTR Param1, _In_ ULONG_PTR Param2)
 
static PAGE_NUMBER StartPartitionOperationsPage (PINPUT_RECORD Ir)
 
static BOOLEAN ChangeSystemPartitionPage (IN PINPUT_RECORD Ir, IN PPARTENTRY SystemPartition)
 
static VOID ResetFileSystemList (VOID)
 
static FSVOL_OP SelectFileSystemPage (_In_ PFSVOL_CONTEXT FsVolContext, _In_ PVOLENTRY Volume)
 
static FSVOL_OP FormatPartitionPage (_In_ PFSVOL_CONTEXT FsVolContext, _In_ PVOLENTRY Volume)
 
static VOID CheckFileSystemPage (_In_ PVOLENTRY Volume)
 
static PAGE_NUMBER InstallDirectoryPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER PrepareCopyPage (PINPUT_RECORD Ir)
 
static VOID SetupUpdateMemoryInfo (IN PCOPYCONTEXT CopyContext, IN BOOLEAN First)
 
static UINT CALLBACK FileCopyCallback (PVOID Context, UINT Notification, UINT_PTR Param1, UINT_PTR Param2)
 
static PAGE_NUMBER FileCopyPage (PINPUT_RECORD Ir)
 
static VOID __cdecl RegistryStatus (IN REGISTRY_STATUS RegStatus,...)
 
static PAGE_NUMBER RegistryPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER BootLoaderSelectPage (PINPUT_RECORD Ir)
 
static BOOLEAN BootLoaderRemovableDiskPage (PINPUT_RECORD Ir)
 
static BOOLEAN BootLoaderHardDiskPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER BootLoaderInstallPage (PINPUT_RECORD Ir)
 
ProgressTimeOutStringHandler

Handles the generation (displaying) of the timeout countdown to the screen dynamically.

Parameters
BarA pointer to a progress bar.
AlwaysUpdateConstantly update the progress bar (boolean type).
BufferA pointer to a string buffer.
cchBufferSizeThe buffer's size in number of characters.
Returns
TRUE or FALSE on function termination.
static BOOLEAN NTAPI ProgressTimeOutStringHandler (IN PPROGRESSBAR Bar, IN BOOLEAN AlwaysUpdate, OUT PSTR Buffer, IN SIZE_T cchBufferSize)
 
ProgressCountdown

Displays and draws a red-coloured progress bar with a countdown. When the timeout is reached, the flush page is displayed for reboot.

Parameters
IrA pointer to an input keyboard record.
TimeOutInitial countdown value in seconds.
Returns
Nothing.
static VOID ProgressCountdown (IN PINPUT_RECORD Ir, IN LONG TimeOut)
 
static PAGE_NUMBER QuitPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER SuccessPage (PINPUT_RECORD Ir)
 
static PAGE_NUMBER FlushPage (PINPUT_RECORD Ir)
 
NTSTATUS RunUSetup (VOID)
 
VOID NTAPI NtProcessStartup (PPEB Peb)
 

Variables

HANDLE ProcessHeap
 
static USETUP_DATA USetupData
 
static PPARTENTRY InstallPartition = NULL
 
static PPARTENTRY SystemPartition = NULL
 
PCWSTR SelectedLanguageId
 
static WCHAR DefaultLanguage [20]
 
static WCHAR DefaultKBLayout [20]
 
static BOOLEAN RepairUpdateFlag = FALSE
 
static PPARTLIST PartitionList = NULL
 
static PPARTENTRY CurrentPartition = NULL
 
static enum { ... }  PartCreateType = PartTypeData
 
static PFILE_SYSTEM_LIST FileSystemList = NULL
 
static PNTOS_INSTALLATION CurrentInstallation = NULL
 
static PGENERIC_LIST NtOsInstallsList = NULL
 

Macro Definition Documentation

◆ InstallVolume

#define InstallVolume   (InstallPartition->Volume)

Definition at line 49 of file usetup.c.

◆ NDEBUG

#define NDEBUG

Definition at line 36 of file usetup.c.

◆ PARTITION_MAXSIZE

#define PARTITION_MAXSIZE   (pow(10, (PARTITION_SIZE_INPUT_FIELD_LENGTH - 1)) - 1)

Definition at line 1848 of file usetup.c.

◆ PARTITION_SIZE_INPUT_FIELD_LENGTH

#define PARTITION_SIZE_INPUT_FIELD_LENGTH   9

Definition at line 1846 of file usetup.c.

◆ SystemVolume

#define SystemVolume   (SystemPartition->Volume)

Definition at line 62 of file usetup.c.

◆ VOLUME_NEW_AUTOCREATE

#define VOLUME_NEW_AUTOCREATE   0x80

Definition at line 84 of file usetup.c.

Typedef Documentation

◆ COPYCONTEXT

◆ FSVOL_CONTEXT

◆ PCOPYCONTEXT

◆ PFSVOL_CONTEXT

Enumeration Type Documentation

◆ anonymous enum

anonymous enum
Enumerator
PartTypeData 
PartTypeExtended 

Definition at line 78 of file usetup.c.

78 {
79 PartTypeData, // On MBR-disks, primary or logical partition
80 PartTypeExtended // MBR-disk container
@ PartTypeData
Definition: usetup.c:79
@ PartTypeExtended
Definition: usetup.c:80
static enum @56 PartCreateType

Function Documentation

◆ BootLoaderHardDiskPage()

static BOOLEAN BootLoaderHardDiskPage ( PINPUT_RECORD  Ir)
static

Definition at line 3626 of file usetup.c.

3627{
3629
3630 /* Copy FreeLoader to the disk and save the boot entries */
3637 ? 1 /* Install MBR and VBR */
3638 : 0 /* Install VBR only */);
3639 if (Status == STATUS_SUCCESS)
3640 return TRUE; /* Successful installation */
3641
3642 if (Status == ERROR_WRITE_BOOT)
3643 {
3644 /* Error when writing the VBR */
3646 SystemVolume->Info.FileSystem);
3647 }
3648 else if (Status == ERROR_INSTALL_BOOTCODE)
3649 {
3650 /* Error when writing the MBR */
3652 }
3653 else if (Status == STATUS_NOT_SUPPORTED)
3654 {
3655 PopupError("Setup does not currently support installing\n"
3656 "the bootloader on the computer you are using.\n"
3657 "Press ENTER to continue anyway.",
3659 Ir, POPUP_WAIT_ENTER);
3660 }
3661 else if (!NT_SUCCESS(Status))
3662 {
3663 /* Any other NTSTATUS failure code */
3665
3666 DPRINT1("InstallBootManagerAndBootEntries() failed: Status 0x%lx\n", Status);
3668 "Setup could not install the bootloader.\n"
3669 "(Status 0x%08lx).\n"
3670 "Press ENTER to continue anyway.",
3671 Status);
3674 Ir, POPUP_WAIT_ENTER);
3675 }
3676 return FALSE;
3677}
LONG NTSTATUS
Definition: precomp.h:26
#define DPRINT1
Definition: precomp.h:8
NTSTATUS NTAPI InstallBootManagerAndBootEntries(_In_ ARCHITECTURE_TYPE ArchType, _In_ PCUNICODE_STRING SystemRootPath, _In_ PCUNICODE_STRING SourceRootPath, _In_ PCUNICODE_STRING DestinationArcPath, _In_ ULONG_PTR Options)
Installs FreeLoader on the system and configure the boot entries.
Definition: bootsup.c:1662
Definition: bufpool.h:45
#define STATUS_NOT_SUPPORTED
Definition: d3dkmdt.h:48
#define TRUE
Definition: types.h:120
#define FALSE
Definition: types.h:117
#define NT_SUCCESS(StatCode)
Definition: apphelp.c:33
#define MAX_PATH
Definition: compat.h:34
@ ERROR_WRITE_BOOT
Definition: errorcode.h:28
@ ERROR_INSTALL_BOOTCODE
Definition: errorcode.h:35
Status
Definition: gdiplustypes.h:25
NTSTRSAFEVAPI RtlStringCbPrintfA(_Out_writes_bytes_(cbDest) _Always_(_Post_z_) NTSTRSAFE_PSTR pszDest, _In_ size_t cbDest, _In_ _Printf_format_string_ NTSTRSAFE_PCSTR pszFormat,...)
Definition: ntstrsafe.h:1148
#define L(x)
Definition: ntvdm.h:50
#define STATUS_SUCCESS
Definition: shellext.h:65
UNICODE_STRING SystemRootPath
Definition: setuplib.h:121
UNICODE_STRING SourceRootPath
Definition: setuplib.h:103
LONG BootLoaderLocation
Definition: setuplib.h:134
ARCHITECTURE_TYPE ArchType
Definition: setuplib.h:147
UNICODE_STRING DestinationArcPath
Definition: setuplib.h:124
VOID __cdecl MUIDisplayError(IN ULONG ErrorNum, OUT PINPUT_RECORD Ir, IN ULONG WaitEvent,...)
Definition: mui.c:237
PCSTR MUIGetString(ULONG Number)
Definition: mui.c:251
#define STRING_CONTINUE
Definition: mui.h:149
#define SystemVolume
Definition: usetup.c:62
VOID PopupError(PCCH Text, PCCH Status, PINPUT_RECORD Ir, ULONG WaitEvent)
Definition: usetup.c:260
static USETUP_DATA USetupData
Definition: usetup.c:44
#define POPUP_WAIT_ENTER
Definition: usetup.h:123
char CHAR
Definition: xmlstorage.h:175

Referenced by BootLoaderInstallPage().

◆ BootLoaderInstallPage()

static PAGE_NUMBER BootLoaderInstallPage ( PINPUT_RECORD  Ir)
static

Definition at line 3692 of file usetup.c.

3693{
3695
3697 RtlStringCchPrintfW(PathBuffer, _countof(PathBuffer),
3698 L"%s\\", SystemPartition->DeviceName);
3700 DPRINT1("SystemRootPath: %wZ\n", &USetupData.SystemRootPath);
3701
3704
3706 {
3707 /* Install on removable disk */
3708 case 1:
3710
3711 /* Install on hard-disk */
3712 case 2: // System partition / MBR and VBR (on BIOS-based PC)
3713 case 3: // VBR only (on BIOS-based PC)
3715
3716 /* Skip installation */
3717 case 0:
3718 default:
3719 return SUCCESS_PAGE;
3720 }
3721}
NTSYSAPI BOOLEAN NTAPI RtlCreateUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
NTSYSAPI VOID NTAPI RtlFreeUnicodeString(PUNICODE_STRING UnicodeString)
#define RTL_NUMBER_OF_FIELD(type, field)
Definition: ntbasedef.h:711
NTSTRSAFEVAPI RtlStringCchPrintfW(_Out_writes_(cchDest) _Always_(_Post_z_) NTSTRSAFE_PWSTR pszDest, _In_ size_t cchDest, _In_ _Printf_format_string_ NTSTRSAFE_PCWSTR pszFormat,...)
Definition: ntstrsafe.h:1110
#define _countof(array)
Definition: sndvol32.h:70
WCHAR DeviceName[MAX_PATH]
NT device name: "\Device\HarddiskM\PartitionN".
Definition: partlist.h:77
VOID MUIDisplayPage(IN ULONG page)
Definition: mui.c:170
static BOOLEAN BootLoaderRemovableDiskPage(PINPUT_RECORD Ir)
Definition: usetup.c:3565
static PPARTENTRY SystemPartition
Definition: usetup.c:60
static BOOLEAN BootLoaderHardDiskPage(PINPUT_RECORD Ir)
Definition: usetup.c:3626
@ SUCCESS_PAGE
Definition: usetup.h:114
@ QUIT_PAGE
Definition: usetup.h:115
@ BOOTLOADER_INSTALL_PAGE
Definition: usetup.h:111
_Must_inspect_result_ _In_ PWDFDEVICE_INIT _In_opt_ PCUNICODE_STRING DeviceName
Definition: wdfdevice.h:3275
__wchar_t WCHAR
Definition: xmlstorage.h:180

Referenced by RunUSetup().

◆ BootLoaderRemovableDiskPage()

static BOOLEAN BootLoaderRemovableDiskPage ( PINPUT_RECORD  Ir)
static

Definition at line 3565 of file usetup.c.

3566{
3568
3569Retry:
3571 CONSOLE_Flush();
3573// CONSOLE_SetStatusText(MUIGetString(STRING_PLEASEWAIT));
3574
3575 while (TRUE)
3576 {
3577 CONSOLE_ConInKey(Ir);
3578
3579 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
3580 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
3581 {
3582 if (ConfirmQuit(Ir))
3583 return FALSE;
3584 break;
3585 }
3586 else if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D) /* ENTER */
3587 {
3588 // FIXME: So far USETUP only supports the 1st floppy.
3589 static const UNICODE_STRING FloppyDrive = RTL_CONSTANT_STRING(L"\\Device\\Floppy0\\");
3591 &FloppyDrive,
3594 if (Status == STATUS_SUCCESS)
3595 return TRUE; /* Successful installation */
3596
3598 {
3600 }
3601 else if (!NT_SUCCESS(Status))
3602 {
3603 /* Any other NTSTATUS failure code */
3605
3606 DPRINT1("InstallBootcodeToRemovable() failed: Status 0x%lx\n", Status);
3608 "Setup could not install the bootloader.\n"
3609 "(Status 0x%08lx).\n"
3610 "Press ENTER to continue anyway.",
3611 Status);
3614 Ir, POPUP_WAIT_ENTER);
3615 }
3616 goto Retry;
3617 }
3618 }
3619 goto Retry;
3620}
NTSTATUS NTAPI InstallBootcodeToRemovable(_In_ ARCHITECTURE_TYPE ArchType, _In_ PCUNICODE_STRING RemovableRootPath, _In_ PCUNICODE_STRING SourceRootPath, _In_ PCUNICODE_STRING DestinationArcPath)
Definition: bootsup.c:1818
_In_ PSCSI_REQUEST_BLOCK _Out_ NTSTATUS _Inout_ BOOLEAN * Retry
Definition: classpnp.h:312
BOOL CONSOLE_Flush(VOID)
Definition: consup.c:175
VOID CONSOLE_ConInKey(OUT PINPUT_RECORD Buffer)
Definition: consup.c:70
VOID CONSOLE_ClearScreen(VOID)
Definition: consup.c:239
static PDISK_IMAGE FloppyDrive[2]
Definition: dskbios32.c:36
@ ERROR_NO_FLOPPY
Definition: errorcode.h:36
#define STATUS_DEVICE_NOT_READY
Definition: shellext.h:70
union _INPUT_RECORD::@3287 Event
KEY_EVENT_RECORD KeyEvent
Definition: wincon.h:275
WORD wVirtualKeyCode
Definition: wincon.h:242
union _KEY_EVENT_RECORD::@3286 uChar
#define RTL_CONSTANT_STRING(s)
Definition: tunneltest.c:14
static BOOL ConfirmQuit(PINPUT_RECORD Ir)
Definition: usetup.c:433
@ BOOTLOADER_REMOVABLE_DISK_PAGE
Definition: usetup.h:112
#define VK_F3
Definition: winuser.h:2260

Referenced by BootLoaderInstallPage().

◆ BootLoaderSelectPage()

static PAGE_NUMBER BootLoaderSelectPage ( PINPUT_RECORD  Ir)
static

Definition at line 3410 of file usetup.c.

3411{
3412 USHORT Line = 12;
3413
3415
3416 /* We must have a supported system partition by now */
3418
3419 /*
3420 * If we repair an existing installation and we made it up to here,
3421 * this means a valid bootloader and boot entry have been found.
3422 * Thus, there is no need to re-install it: skip its installation.
3423 */
3424 if (RepairUpdateFlag)
3425 {
3427 goto Quit;
3428 }
3429
3430 /* For unattended setup, skip MBR installation or install on removable disk if needed */
3432 {
3433 if ((USetupData.BootLoaderLocation == 0) ||
3435 {
3436 goto Quit;
3437 }
3438 }
3439
3440#if 0 // Deprecated code, whose global logic may need to be moved elsewhere...
3441 /*
3442 * We may install an MBR or VBR, but before that, check whether
3443 * we need to actually install the VBR on removable disk if the
3444 * system partition is not recognized.
3445 */
3446 if ((SystemPartition->DiskEntry->DiskStyle != PARTITION_STYLE_MBR) ||
3448 {
3450 goto Quit;
3451 }
3452#endif
3453
3454 /* Is it an unattended install on hdd? */
3456 {
3457 if ((USetupData.BootLoaderLocation == 2) ||
3459 {
3460 goto Quit;
3461 }
3462 }
3463
3465 CONSOLE_InvertTextXY(8, Line, 60, 1);
3466
3467 while (TRUE)
3468 {
3469 CONSOLE_ConInKey(Ir);
3470
3471 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
3472 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_DOWN)) /* DOWN */
3473 {
3474 CONSOLE_NormalTextXY(8, Line, 60, 1);
3475
3476 Line++;
3477 if (Line < 12)
3478 Line = 15;
3479
3480 if (Line > 15)
3481 Line = 12;
3482
3483 CONSOLE_InvertTextXY(8, Line, 60, 1);
3484 }
3485 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
3486 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_UP)) /* UP */
3487 {
3488 CONSOLE_NormalTextXY(8, Line, 60, 1);
3489
3490 Line--;
3491 if (Line < 12)
3492 Line = 15;
3493
3494 if (Line > 15)
3495 Line = 12;
3496
3497 CONSOLE_InvertTextXY(8, Line, 60, 1);
3498 }
3499 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
3500 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_HOME)) /* HOME */
3501 {
3502 CONSOLE_NormalTextXY(8, Line, 60, 1);
3503
3504 Line = 12;
3505
3506 CONSOLE_InvertTextXY(8, Line, 60, 1);
3507 }
3508 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
3509 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_END)) /* END */
3510 {
3511 CONSOLE_NormalTextXY(8, Line, 60, 1);
3512
3513 Line = 15;
3514
3515 CONSOLE_InvertTextXY(8, Line, 60, 1);
3516 }
3517 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
3518 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
3519 {
3520 if (ConfirmQuit(Ir))
3521 return QUIT_PAGE;
3522 break;
3523 }
3524 else if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D) /* ENTER */
3525 {
3526 if (Line == 12)
3527 {
3528 /* Install on both MBR and VBR */
3530 break;
3531 }
3532 else if (Line == 13)
3533 {
3534 /* Install on VBR only */
3536 break;
3537 }
3538 else if (Line == 14)
3539 {
3540 /* Install on removable disk */
3542 break;
3543 }
3544 else if (Line == 15)
3545 {
3546 /* Skip installation */
3548 break;
3549 }
3550
3552 }
3553 }
3554
3555Quit:
3556 /* Continue the installation; the bootloader is installed at the end */
3558}
VOID CONSOLE_InvertTextXY(IN SHORT x, IN SHORT y, IN SHORT col, IN SHORT row)
Definition: consup.c:276
VOID CONSOLE_NormalTextXY(IN SHORT x, IN SHORT y, IN SHORT col, IN SHORT row)
Definition: consup.c:298
VOID __cdecl CONSOLE_SetStatusText(IN LPCSTR fmt,...)
Definition: consup.c:480
#define ASSERT(a)
Definition: mode.c:44
@ PARTITION_STYLE_MBR
Definition: imports.h:201
#define IsRecognizedPartition(PartitionType)
Definition: ntdddisk.h:342
unsigned short USHORT
Definition: pedump.c:61
BOOLEAN IsUnattendedSetup
Definition: setuplib.c:26
Definition: ncftp.h:79
BOOLEAN IsPartitioned
Definition: partlist.h:82
UCHAR PartitionType
Definition: partlist.h:73
struct _DISKENTRY * DiskEntry
Definition: partlist.h:66
ULONG PartitionNumber
Definition: partlist.h:75
#define STRING_PLEASEWAIT
Definition: mui.h:132
static BOOLEAN RepairUpdateFlag
Definition: usetup.c:71
@ BOOTLOADER_SELECT_PAGE
Definition: usetup.h:105
@ INSTALL_DIRECTORY_PAGE
Definition: usetup.h:108
#define VK_UP
Definition: winuser.h:2228
#define VK_END
Definition: winuser.h:2225
#define VK_HOME
Definition: winuser.h:2226
#define VK_DOWN
Definition: winuser.h:2230

Referenced by RunUSetup().

◆ ChangeSystemPartitionPage()

static BOOLEAN ChangeSystemPartitionPage ( IN PINPUT_RECORD  Ir,
IN PPARTENTRY  SystemPartition 
)
static

Definition at line 2316 of file usetup.c.

2319{
2320 PPARTENTRY PartEntry;
2321 PDISKENTRY DiskEntry;
2322 CHAR LineBuffer[100];
2323
2324 // CONSOLE_ClearScreen();
2325 // CONSOLE_Flush();
2327
2328 PartEntry = PartitionList->SystemPartition;
2329 DiskEntry = PartEntry->DiskEntry;
2330
2331 PartitionDescription(PartEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2332 CONSOLE_SetTextXY(8, 10, LineBuffer);
2333
2334 DiskDescription(DiskEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2336 LineBuffer);
2337
2338
2339 PartEntry = SystemPartition;
2340 DiskEntry = PartEntry->DiskEntry;
2341
2342 PartitionDescription(PartEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2343 CONSOLE_SetTextXY(8, 23, LineBuffer);
2344
2345 while (TRUE)
2346 {
2347 CONSOLE_ConInKey(Ir);
2348
2349 if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_RETURN) /* ENTER */
2350 break;
2351 else if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_ESCAPE) /* ESC */
2352 return FALSE;
2353 }
2354
2355 return TRUE;
2356}
VOID CONSOLE_SetTextXY(IN SHORT x, IN SHORT y, IN LPCSTR Text)
Definition: consup.c:320
VOID __cdecl CONSOLE_PrintTextXY(IN SHORT x, IN SHORT y, IN LPCSTR fmt,...)
Definition: consup.c:595
#define ARRAYSIZE(array)
Definition: filtermapper.c:47
VOID PartitionDescription(IN PPARTENTRY PartEntry, OUT PSTR strBuffer, IN SIZE_T cchBuffer)
Definition: partlist.c:148
VOID DiskDescription(IN PDISKENTRY DiskEntry, OUT PSTR strBuffer, IN SIZE_T cchBuffer)
Definition: partlist.c:301
PPARTENTRY SystemPartition
Definition: partlist.h:181
#define STRING_HDDISK1
Definition: mui.h:173
static PPARTLIST PartitionList
Definition: usetup.c:74
@ CHANGE_SYSTEM_PARTITION
Definition: usetup.h:97
#define VK_RETURN
Definition: winuser.h:2204
#define VK_ESCAPE
Definition: winuser.h:2217

Referenced by FsVolCallback().

◆ CheckFileSystemPage()

static VOID CheckFileSystemPage ( _In_ PVOLENTRY  Volume)
static

Definition at line 2578 of file usetup.c.

2580{
2581 PPARTENTRY PartEntry = Volume->PartEntry;
2582 PDISKENTRY DiskEntry = PartEntry->DiskEntry;
2583 CHAR LineBuffer[100];
2584
2586 CONSOLE_Flush();
2588
2589 PartitionDescription(PartEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2590 CONSOLE_SetTextXY(6, 10, LineBuffer);
2591
2592 DiskDescription(DiskEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2594 LineBuffer);
2595}
UNICODE_STRING Volume
Definition: fltkernel.h:1172
#define STRING_HDDISK2
Definition: mui.h:174
@ CHECK_FILE_SYSTEM_PAGE
Definition: usetup.h:104

Referenced by FsVolCallback().

◆ ComputerSettingsPage()

static PAGE_NUMBER ComputerSettingsPage ( PINPUT_RECORD  Ir)
static

Definition at line 1424 of file usetup.c.

1425{
1426 GENERIC_LIST_UI ListUi;
1428
1430 DrawGenericList(&ListUi,
1431 2, 18,
1432 xScreen - 3,
1433 yScreen - 3);
1434
1435 return HandleGenericList(&ListUi, DEVICE_SETTINGS_PAGE, Ir);
1436}
SHORT yScreen
Definition: consup.c:40
SHORT xScreen
Definition: consup.c:39
PGENERIC_LIST ComputerList
Definition: setuplib.h:140
VOID InitGenericListUi(IN OUT PGENERIC_LIST_UI ListUi, IN PGENERIC_LIST List, IN PGET_ENTRY_DESCRIPTION GetEntryDescriptionProc)
Definition: genlist.c:37
VOID DrawGenericList(IN PGENERIC_LIST_UI ListUi, IN SHORT Left, IN SHORT Top, IN SHORT Right, IN SHORT Bottom)
Definition: genlist.c:326
static NTSTATUS NTAPI GetSettingDescription(IN PGENERIC_LIST_ENTRY Entry, OUT PSTR Buffer, IN SIZE_T cchBufferSize)
Definition: usetup.c:497
static PAGE_NUMBER HandleGenericList(PGENERIC_LIST_UI ListUi, PAGE_NUMBER nextPage, PINPUT_RECORD Ir)
Definition: usetup.c:1360
@ COMPUTER_SETTINGS_PAGE
Definition: usetup.h:90
@ DEVICE_SETTINGS_PAGE
Definition: usetup.h:89

Referenced by RunUSetup().

◆ ConfirmDeleteSystemPartitionPage()

static PAGE_NUMBER ConfirmDeleteSystemPartitionPage ( PINPUT_RECORD  Ir)
static

Definition at line 2153 of file usetup.c.

2154{
2156
2157 while (TRUE)
2158 {
2159 CONSOLE_ConInKey(Ir);
2160
2161 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2162 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
2163 {
2164 if (ConfirmQuit(Ir))
2165 return QUIT_PAGE;
2166 break;
2167 }
2168 else if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_RETURN) /* ENTER */
2169 {
2170 return DELETE_PARTITION_PAGE;
2171 }
2172 else if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_ESCAPE) /* ESC */
2173 {
2174 return SELECT_PARTITION_PAGE;
2175 }
2176 }
2177
2179}
@ DELETE_PARTITION_PAGE
Definition: usetup.h:99
@ SELECT_PARTITION_PAGE
Definition: usetup.h:95
@ CONFIRM_DELETE_SYSTEM_PARTITION_PAGE
Definition: usetup.h:98

Referenced by RunUSetup().

◆ ConfirmQuit()

static BOOL ConfirmQuit ( PINPUT_RECORD  Ir)
static

Definition at line 433 of file usetup.c.

434{
435 BOOL Result = FALSE;
437
438 while (TRUE)
439 {
441
442 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
443 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
444 {
445 Result = TRUE;
446 break;
447 }
448 else if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D) /* ENTER */
449 {
450 Result = FALSE;
451 break;
452 }
453 }
454
455 return Result;
456}
#define NULL
Definition: types.h:112
unsigned int BOOL
Definition: ntddk_ex.h:94
#define ERROR_NOT_INSTALLED
Definition: setupapi.h:292
#define POPUP_WAIT_NONE
Definition: usetup.h:121
_At_(*)(_In_ PWSK_CLIENT Client, _In_opt_ PUNICODE_STRING NodeName, _In_opt_ PUNICODE_STRING ServiceName, _In_opt_ ULONG NameSpace, _In_opt_ GUID *Provider, _In_opt_ PADDRINFOEXW Hints, _Outptr_ PADDRINFOEXW *Result, _In_opt_ PEPROCESS OwningProcess, _In_opt_ PETHREAD OwningThread, _Inout_ PIRP Irp Result)(Mem)) NTSTATUS(WSKAPI *PFN_WSK_GET_ADDRESS_INFO
Definition: wsk.h:409

Referenced by BootLoaderRemovableDiskPage(), BootLoaderSelectPage(), ConfirmDeleteSystemPartitionPage(), CreatePartitionPage(), DeletePartitionPage(), DeviceSettingsPage(), FormatPartitionPage(), FsVolCallback(), HandleGenericList(), InstallDirectoryPage(), InstallIntroPage(), LanguagePage(), SelectFileSystemPage(), SelectPartitionPage(), UpgradeRepairPage(), and WelcomePage().

◆ CreatePartitionPage()

static PAGE_NUMBER CreatePartitionPage ( PINPUT_RECORD  Ir)
static

Definition at line 2044 of file usetup.c.

2045{
2046 PPARTENTRY PartEntry;
2047 PDISKENTRY DiskEntry;
2048 ULONG uID;
2049 ULONG MaxSize;
2050 ULONGLONG MaxPartSize, PartSize;
2051 BOOLEAN Quit, Cancel;
2052 WCHAR InputBuffer[50];
2053 CHAR LineBuffer[100];
2054
2056 {
2057 /* FIXME: show an error dialog */
2058 return QUIT_PAGE;
2059 }
2060
2062 {
2066 }
2067 else // if (PartCreateType == PartTypeExtended)
2068 {
2070 }
2071
2072 CONSOLE_SetTextXY(6, 8, MUIGetString(uID));
2073
2074 PartEntry = CurrentPartition;
2075 DiskEntry = CurrentPartition->DiskEntry;
2076
2077 DiskDescription(DiskEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2079 LineBuffer);
2080
2082
2084
2085 MaxPartSize = GetPartEntrySizeInBytes(PartEntry);
2086
2087 while (TRUE)
2088 {
2089 /* Retrieve the maximum size in MB (rounded up)
2090 * and cap it with what the user can enter */
2091 MaxSize = (ULONG)RoundingDivide(MaxPartSize, MB);
2092 MaxSize = min(MaxSize, PARTITION_MAXSIZE);
2093
2094 ShowPartitionSizeInputBox(12, 14, xScreen - 12, 17,
2095 MaxSize, InputBuffer, &Quit, &Cancel);
2096 if (Quit)
2097 {
2098 if (ConfirmQuit(Ir))
2099 return QUIT_PAGE;
2100 break;
2101 }
2102 else if (Cancel)
2103 {
2104 return SELECT_PARTITION_PAGE;
2105 }
2106
2107 PartSize = _wcstoui64(InputBuffer, NULL, 10);
2108
2109 /* Retry if too small or too large */
2110 if ((PartSize < 1) || (PartSize > MaxSize))
2111 continue;
2112
2113 /*
2114 * If the input size, given in MB, specifies the maximum partition
2115 * size, it may slightly under- or over-estimate the latter due to
2116 * rounding error. In this case, use all of the unpartitioned space.
2117 * Otherwise, directly convert the size to bytes.
2118 */
2119 if (PartSize == MaxSize)
2120 PartSize = MaxPartSize;
2121 else // if (PartSize < MaxSize)
2122 PartSize *= MB;
2123 DPRINT("Partition size: %I64u bytes\n", PartSize);
2124
2125 ASSERT(PartSize <= MaxPartSize);
2126
2129 PartSize,
2131 ? 0
2132 // (PartCreateType == PartTypeExtended)
2134
2135 return SELECT_PARTITION_PAGE;
2136 }
2137
2138 return CREATE_PARTITION_PAGE;
2139}
unsigned char BOOLEAN
#define PARTITION_EXTENDED
Definition: disk.h:92
#define GetPartEntrySizeInBytes(PartEntry)
Definition: partlist.h:254
void Cancel(int sigNum)
Definition: shell.c:481
#define min(a, b)
Definition: monoChain.cc:55
ULONGLONG RoundingDivide(IN ULONGLONG Dividend, IN ULONGLONG Divisor)
Definition: partlist.c:95
BOOLEAN NTAPI CreatePartition(_In_ PPARTLIST List, _Inout_ PPARTENTRY PartEntry, _In_opt_ ULONGLONG SizeBytes, _In_opt_ ULONG_PTR PartitionInfo)
Definition: partlist.c:2910
#define MB
Definition: setuplib.h:77
#define DPRINT
Definition: sndvol32.h:73
BOOLEAN LogicalPartition
Definition: partlist.h:79
uint32_t ULONG
Definition: typedefs.h:59
uint64_t ULONGLONG
Definition: typedefs.h:67
#define STRING_CREATEPARTITION
Definition: mui.h:142
#define STRING_CHOOSE_NEW_EXTENDED_PARTITION
Definition: mui.h:139
#define STRING_CHOOSE_NEW_PARTITION
Definition: mui.h:138
#define STRING_HDPARTSIZE
Definition: mui.h:141
#define STRING_CHOOSE_NEW_LOGICAL_PARTITION
Definition: mui.h:140
static PPARTENTRY CurrentPartition
Definition: usetup.c:77
#define PARTITION_MAXSIZE
Definition: usetup.c:1848
static VOID ShowPartitionSizeInputBox(SHORT Left, SHORT Top, SHORT Right, SHORT Bottom, ULONG MaxSize, PWSTR InputBuffer, PBOOLEAN Quit, PBOOLEAN Cancel)
Definition: usetup.c:1851
@ CREATE_PARTITION_PAGE
Definition: usetup.h:96
_Must_inspect_result_ _In_ WDFIOTARGET _In_opt_ WDFREQUEST _In_opt_ PWDF_MEMORY_DESCRIPTOR InputBuffer
Definition: wdfiotarget.h:953
unsigned __int64 CDECL _wcstoui64(const wchar_t *nptr, wchar_t **endptr, int base)
Definition: wtoi64.c:200

Referenced by RunUSetup().

◆ DeletePartitionPage()

static PAGE_NUMBER DeletePartitionPage ( PINPUT_RECORD  Ir)
static

Definition at line 2193 of file usetup.c.

2194{
2195 PPARTENTRY PartEntry;
2196 PDISKENTRY DiskEntry;
2197 CHAR LineBuffer[100];
2198
2200 {
2201 /* FIXME: show an error dialog */
2202 return QUIT_PAGE;
2203 }
2204
2205 PartEntry = CurrentPartition;
2206 DiskEntry = CurrentPartition->DiskEntry;
2207
2209
2210 PartitionDescription(PartEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2211 CONSOLE_SetTextXY(6, 10, LineBuffer);
2212
2213 DiskDescription(DiskEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2215 LineBuffer);
2216
2217 while (TRUE)
2218 {
2219 CONSOLE_ConInKey(Ir);
2220
2221 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2222 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
2223 {
2224 if (ConfirmQuit(Ir))
2225 return QUIT_PAGE;
2226 break;
2227 }
2228 else if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_ESCAPE) /* ESC */
2229 {
2230 return SELECT_PARTITION_PAGE;
2231 }
2232 else if (Ir->Event.KeyEvent.wVirtualKeyCode == 'L') /* L */
2233 {
2237 return SELECT_PARTITION_PAGE;
2238 }
2239 }
2240
2241 return DELETE_PARTITION_PAGE;
2242}
BOOLEAN NTAPI DeletePartition(_In_ PPARTLIST List, _In_ PPARTENTRY PartEntry, _Out_opt_ PPARTENTRY *FreeRegion)
Definition: partlist.c:3001

Referenced by RunUSetup().

◆ DeviceSettingsPage()

static PAGE_NUMBER DeviceSettingsPage ( PINPUT_RECORD  Ir)
static

Definition at line 1229 of file usetup.c.

1230{
1231 static ULONG Line = 16;
1232
1233 /* Initialize the computer settings list */
1235 {
1238 {
1240 return QUIT_PAGE;
1241 }
1242 }
1243
1244 /* Initialize the display settings list */
1246 {
1249 {
1251 return QUIT_PAGE;
1252 }
1253 }
1254
1255 /* Initialize the keyboard settings list */
1257 {
1260 {
1262 return QUIT_PAGE;
1263 }
1264 }
1265
1266 /* Initialize the keyboard layout list */
1268 {
1271 {
1272 /* FIXME: report error */
1274 return QUIT_PAGE;
1275 }
1276 }
1277
1278 if (RepairUpdateFlag)
1279 return SELECT_PARTITION_PAGE;
1280
1281 // if (IsUnattendedSetup)
1282 // return SELECT_PARTITION_PAGE;
1283
1285
1290
1291 CONSOLE_InvertTextXY(24, Line, 48, 1);
1292
1293 while (TRUE)
1294 {
1295 CONSOLE_ConInKey(Ir);
1296
1297 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1298 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_DOWN)) /* DOWN */
1299 {
1300 CONSOLE_NormalTextXY(24, Line, 48, 1);
1301
1302 if (Line == 14)
1303 Line = 16;
1304 else if (Line == 16)
1305 Line = 11;
1306 else
1307 Line++;
1308
1309 CONSOLE_InvertTextXY(24, Line, 48, 1);
1310 }
1311 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1312 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_UP)) /* UP */
1313 {
1314 CONSOLE_NormalTextXY(24, Line, 48, 1);
1315
1316 if (Line == 11)
1317 Line = 16;
1318 else if (Line == 16)
1319 Line = 14;
1320 else
1321 Line--;
1322
1323 CONSOLE_InvertTextXY(24, Line, 48, 1);
1324 }
1325 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1326 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
1327 {
1328 if (ConfirmQuit(Ir))
1329 return QUIT_PAGE;
1330 break;
1331 }
1332 else if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D) /* ENTER */
1333 {
1334 if (Line == 11)
1336 else if (Line == 12)
1337 return DISPLAY_SETTINGS_PAGE;
1338 else if (Line == 13)
1340 else if (Line == 14)
1341 return LAYOUT_SETTINGS_PAGE;
1342 else if (Line == 16)
1343 return SELECT_PARTITION_PAGE;
1344 }
1345 }
1346
1347 return DEVICE_SETTINGS_PAGE;
1348}
PGENERIC_LIST CreateKeyboardDriverList(IN HINF InfFile)
Definition: settings.c:1072
PGENERIC_LIST CreateComputerTypeList(IN HINF InfFile)
Definition: settings.c:524
PGENERIC_LIST CreateDisplayDriverList(IN HINF InfFile)
Definition: settings.c:708
PGENERIC_LIST CreateKeyboardLayoutList(IN HINF InfFile, IN PCWSTR LanguageId, OUT PWSTR DefaultKBLayout)
Definition: settings.c:1209
@ ERROR_LOAD_KBLAYOUT
Definition: errorcode.h:32
@ ERROR_LOAD_KEYBOARD
Definition: errorcode.h:31
@ ERROR_LOAD_DISPLAY
Definition: errorcode.h:30
@ ERROR_LOAD_COMPUTER
Definition: errorcode.h:29
PGENERIC_LIST DisplayList
Definition: setuplib.h:141
PGENERIC_LIST LayoutList
Definition: setuplib.h:143
HINF SetupInf
Definition: setuplib.h:97
PGENERIC_LIST KeyboardList
Definition: setuplib.h:142
VOID DrawGenericListCurrentItem(IN PGENERIC_LIST List, IN PGET_ENTRY_DESCRIPTION GetEntryDescriptionProc, IN SHORT Left, IN SHORT Top)
Definition: genlist.c:353
static WCHAR DefaultKBLayout[20]
Definition: usetup.c:69
PCWSTR SelectedLanguageId
Definition: usetup.c:67
@ LAYOUT_SETTINGS_PAGE
Definition: usetup.h:93
@ DISPLAY_SETTINGS_PAGE
Definition: usetup.h:91
@ KEYBOARD_SETTINGS_PAGE
Definition: usetup.h:92

Referenced by RunUSetup().

◆ DisplaySettingsPage()

static PAGE_NUMBER DisplaySettingsPage ( PINPUT_RECORD  Ir)
static

Definition at line 1450 of file usetup.c.

1451{
1452 GENERIC_LIST_UI ListUi;
1454
1456 DrawGenericList(&ListUi,
1457 2, 18,
1458 xScreen - 3,
1459 yScreen - 3);
1460
1461 return HandleGenericList(&ListUi, DEVICE_SETTINGS_PAGE, Ir);
1462}

Referenced by RunUSetup().

◆ DrawBox()

static VOID DrawBox ( IN SHORT  xLeft,
IN SHORT  yTop,
IN SHORT  Width,
IN SHORT  Height 
)
static

Definition at line 170 of file usetup.c.

174{
175 COORD coPos;
176 DWORD Written;
177
178 /* Draw upper left corner */
179 coPos.X = xLeft;
180 coPos.Y = yTop;
182 CharUpperLeftCorner, // '+',
183 1,
184 coPos,
185 &Written);
186
187 /* Draw upper edge */
188 coPos.X = xLeft + 1;
189 coPos.Y = yTop;
191 CharHorizontalLine, // '-',
192 Width - 2,
193 coPos,
194 &Written);
195
196 /* Draw upper right corner */
197 coPos.X = xLeft + Width - 1;
198 coPos.Y = yTop;
200 CharUpperRightCorner, // '+',
201 1,
202 coPos,
203 &Written);
204
205 /* Draw right edge, inner space and left edge */
206 for (coPos.Y = yTop + 1; coPos.Y < yTop + Height - 1; coPos.Y++)
207 {
208 coPos.X = xLeft;
210 CharVerticalLine, // '|',
211 1,
212 coPos,
213 &Written);
214
215 coPos.X = xLeft + 1;
217 ' ',
218 Width - 2,
219 coPos,
220 &Written);
221
222 coPos.X = xLeft + Width - 1;
224 CharVerticalLine, // '|',
225 1,
226 coPos,
227 &Written);
228 }
229
230 /* Draw lower left corner */
231 coPos.X = xLeft;
232 coPos.Y = yTop + Height - 1;
234 CharLowerLeftCorner, // '+',
235 1,
236 coPos,
237 &Written);
238
239 /* Draw lower edge */
240 coPos.X = xLeft + 1;
241 coPos.Y = yTop + Height - 1;
243 CharHorizontalLine, // '-',
244 Width - 2,
245 coPos,
246 &Written);
247
248 /* Draw lower right corner */
249 coPos.X = xLeft + Width - 1;
250 coPos.Y = yTop + Height - 1;
252 CharLowerRightCorner, // '+',
253 1,
254 coPos,
255 &Written);
256}
BOOL WINAPI FillConsoleOutputCharacterA(IN HANDLE hConsoleOutput, IN CHAR cCharacter, IN DWORD nLength, IN COORD dwWriteCoord, OUT LPDWORD lpNumberOfCharsWritten)
Definition: console.c:560
HANDLE StdOutput
Definition: consup.c:37
unsigned long DWORD
Definition: ntddk_ex.h:95
Definition: bl.h:1338
ULONG Y
Definition: bl.h:1340
ULONG X
Definition: bl.h:1339
_In_ HFONT _Out_ PUINT _Out_ PUINT Width
Definition: font.h:89
_In_ HFONT _Out_ PUINT Height
Definition: font.h:88
CHAR CharHorizontalLine
Definition: mui.c:39
CHAR CharUpperRightCorner
Definition: mui.c:42
CHAR CharLowerRightCorner
Definition: mui.c:44
CHAR CharUpperLeftCorner
Definition: mui.c:41
CHAR CharVerticalLine
Definition: mui.c:40
CHAR CharLowerLeftCorner
Definition: mui.c:43

Referenced by PopupError(), and ShowPartitionSizeInputBox().

◆ FileCopyCallback()

static UINT CALLBACK FileCopyCallback ( PVOID  Context,
UINT  Notification,
UINT_PTR  Param1,
UINT_PTR  Param2 
)
static

Definition at line 3130 of file usetup.c.

3134{
3135 PCOPYCONTEXT CopyContext = (PCOPYCONTEXT)Context;
3136 PFILEPATHS_W FilePathInfo;
3137 PCWSTR SrcFileName, DstFileName;
3138
3139 switch (Notification)
3140 {
3142 {
3143 CopyContext->TotalOperations = (ULONG)Param2;
3144 CopyContext->CompletedOperations = 0;
3145 ProgressSetStepCount(CopyContext->ProgressBar,
3146 CopyContext->TotalOperations);
3147 SetupUpdateMemoryInfo(CopyContext, TRUE);
3148 break;
3149 }
3150
3154 {
3155 FilePathInfo = (PFILEPATHS_W)Param1;
3156
3158 {
3159 /* Display delete message */
3160 ASSERT(Param2 == FILEOP_DELETE);
3161
3162 DstFileName = wcsrchr(FilePathInfo->Target, L'\\');
3163 if (DstFileName) ++DstFileName;
3164 else DstFileName = FilePathInfo->Target;
3165
3167 DstFileName);
3168 }
3170 {
3171 /* Display move/rename message */
3172 ASSERT(Param2 == FILEOP_RENAME);
3173
3174 SrcFileName = wcsrchr(FilePathInfo->Source, L'\\');
3175 if (SrcFileName) ++SrcFileName;
3176 else SrcFileName = FilePathInfo->Source;
3177
3178 DstFileName = wcsrchr(FilePathInfo->Target, L'\\');
3179 if (DstFileName) ++DstFileName;
3180 else DstFileName = FilePathInfo->Target;
3181
3182 if (!_wcsicmp(SrcFileName, DstFileName))
3183 Param2 = STRING_MOVING;
3184 else
3185 Param2 = STRING_RENAMING;
3186
3188 SrcFileName, DstFileName);
3189 }
3191 {
3192 static PCSTR s_pszCopying = NULL; /* Cached for speed */
3193
3194 /* Display copy message */
3195 ASSERT(Param2 == FILEOP_COPY);
3196
3197 /* NOTE: When extracting from CABs the Source is the CAB name */
3198 DstFileName = wcsrchr(FilePathInfo->Target, L'\\');
3199 if (DstFileName) ++DstFileName;
3200 else DstFileName = FilePathInfo->Target;
3201
3202 if (!s_pszCopying)
3203 s_pszCopying = MUIGetString(STRING_COPYING);
3204 CONSOLE_SetStatusText(s_pszCopying, DstFileName);
3205#ifdef __REACTOS__ /* HACK */
3206 DoWatchDestFileName(DstFileName);
3207#endif
3208 }
3209
3210 SetupUpdateMemoryInfo(CopyContext, FALSE);
3211 break;
3212 }
3213
3215 {
3216 FilePathInfo = (PFILEPATHS_W)Param1;
3217
3218 DPRINT1("An error happened while trying to copy file '%S' (error 0x%08lx), skipping it...\n",
3219 FilePathInfo->Target, FilePathInfo->Win32Error);
3220 return FILEOP_SKIP;
3221 }
3222
3226 {
3227 CopyContext->CompletedOperations++;
3228
3229 /* SYSREG checkpoint */
3230 if (CopyContext->TotalOperations >> 1 == CopyContext->CompletedOperations)
3231 DPRINT1("CHECKPOINT:HALF_COPIED\n");
3232
3233 ProgressNextStep(CopyContext->ProgressBar);
3234 SetupUpdateMemoryInfo(CopyContext, FALSE);
3235 break;
3236 }
3237 }
3238
3239 return FILEOP_DOIT;
3240}
VOID ProgressNextStep(IN PPROGRESSBAR Bar)
Definition: progress.c:361
VOID ProgressSetStepCount(IN PPROGRESSBAR Bar, IN ULONG StepCount)
Definition: progress.c:347
#define wcsrchr
Definition: compat.h:16
#define SPFILENOTIFY_ENDDELETE
Definition: fileqsup.h:28
#define FILEOP_COPY
Definition: fileqsup.h:42
struct _FILEPATHS_W * PFILEPATHS_W
#define FILEOP_SKIP
Definition: fileqsup.h:49
#define SPFILENOTIFY_STARTDELETE
Definition: fileqsup.h:27
#define SPFILENOTIFY_STARTSUBQUEUE
Definition: fileqsup.h:24
#define FILEOP_DOIT
Definition: fileqsup.h:48
#define SPFILENOTIFY_ENDCOPY
Definition: fileqsup.h:36
#define SPFILENOTIFY_STARTCOPY
Definition: fileqsup.h:35
#define SPFILENOTIFY_COPYERROR
Definition: fileqsup.h:37
#define FILEOP_RENAME
Definition: fileqsup.h:43
#define SPFILENOTIFY_STARTRENAME
Definition: fileqsup.h:31
#define SPFILENOTIFY_ENDRENAME
Definition: fileqsup.h:32
#define FILEOP_DELETE
Definition: fileqsup.h:44
_Check_return_ _CRTIMP int __cdecl _wcsicmp(_In_z_ const wchar_t *_Str1, _In_z_ const wchar_t *_Str2)
ULONG TotalOperations
Definition: reactos.c:1590
ULONG CompletedOperations
Definition: reactos.c:1591
PPROGRESSBAR ProgressBar
Definition: usetup.c:3097
UINT Win32Error
Definition: fileqsup.h:62
PCWSTR Source
Definition: fileqsup.h:61
PCWSTR Target
Definition: fileqsup.h:60
const uint16_t * PCWSTR
Definition: typedefs.h:57
const char * PCSTR
Definition: typedefs.h:52
#define STRING_COPYING
Definition: mui.h:155
#define STRING_MOVING
Definition: mui.h:153
#define STRING_DELETING
Definition: mui.h:152
#define STRING_RENAMING
Definition: mui.h:154
struct _COPYCONTEXT * PCOPYCONTEXT
static VOID SetupUpdateMemoryInfo(IN PCOPYCONTEXT CopyContext, IN BOOLEAN First)
Definition: usetup.c:3102
_In_ PWDFDEVICE_INIT _In_ PFN_WDF_DEVICE_SHUTDOWN_NOTIFICATION Notification
Definition: wdfcontrol.h:115

Referenced by FileCopyPage().

◆ FileCopyPage()

static PAGE_NUMBER FileCopyPage ( PINPUT_RECORD  Ir)
static

Definition at line 3256 of file usetup.c.

3257{
3258 COPYCONTEXT CopyContext;
3259 UINT MemBarWidth;
3260
3262
3263 /* Create context for the copy process */
3264 CopyContext.TotalOperations = 0;
3265 CopyContext.CompletedOperations = 0;
3266
3267 /* Create the progress bar as well */
3268 CopyContext.ProgressBar = CreateProgressBar(13,
3269 26,
3270 xScreen - 13,
3271 yScreen - 20,
3272 10,
3273 24,
3274 TRUE,
3276
3277 // fit memory bars to screen width, distribute them uniform
3278 MemBarWidth = (xScreen - 26) / 5;
3279 MemBarWidth -= MemBarWidth % 2; // make even
3280 /* ATTENTION: The following progress bars are debug stuff, which should not be translated!! */
3281 /* Create the paged pool progress bar */
3282 CopyContext.MemoryBars[0] = CreateProgressBar(13,
3283 40,
3284 13 + MemBarWidth,
3285 43,
3286 13,
3287 44,
3288 FALSE,
3289 "Kernel Pool");
3290
3291 /* Create the non paged pool progress bar */
3292 CopyContext.MemoryBars[1] = CreateProgressBar((xScreen / 2)- (MemBarWidth / 2),
3293 40,
3294 (xScreen / 2) + (MemBarWidth / 2),
3295 43,
3296 (xScreen / 2)- (MemBarWidth / 2),
3297 44,
3298 FALSE,
3299 "Kernel Cache");
3300
3301 /* Create the global memory progress bar */
3302 CopyContext.MemoryBars[2] = CreateProgressBar(xScreen - 13 - MemBarWidth,
3303 40,
3304 xScreen - 13,
3305 43,
3306 xScreen - 13 - MemBarWidth,
3307 44,
3308 FALSE,
3309 "Free Memory");
3310
3311 /* Do the file copying */
3312 DoFileCopy(&USetupData, FileCopyCallback, &CopyContext);
3313
3314 /* If we get here, we're done, so cleanup the progress bar */
3315 DestroyProgressBar(CopyContext.ProgressBar);
3316 DestroyProgressBar(CopyContext.MemoryBars[0]);
3317 DestroyProgressBar(CopyContext.MemoryBars[1]);
3318 DestroyProgressBar(CopyContext.MemoryBars[2]);
3319
3320 /* Create the $winnt$.inf file */
3322
3323 /* Go display the next page */
3324 return REGISTRY_PAGE;
3325}
BOOLEAN NTAPI DoFileCopy(IN OUT PUSETUP_DATA pSetupData, IN PSP_FILE_CALLBACK_W MsgHandler, IN PVOID Context OPTIONAL)
Definition: install.c:828
PPROGRESSBAR CreateProgressBar(IN SHORT Left, IN SHORT Top, IN SHORT Right, IN SHORT Bottom, IN SHORT TextTop, IN SHORT TextRight, IN BOOLEAN DoubleEdge, IN PCSTR DescriptionText OPTIONAL)
Definition: progress.c:317
VOID DestroyProgressBar(IN OUT PPROGRESSBAR Bar)
Definition: progress.c:339
unsigned int UINT
Definition: ndis.h:50
VOID NTAPI InstallSetupInfFile(IN OUT PUSETUP_DATA pSetupData)
Definition: setuplib.c:207
PPROGRESSBAR MemoryBars[4]
Definition: usetup.c:3098
#define STRING_SETUPCOPYINGFILES
Definition: mui.h:156
static UINT CALLBACK FileCopyCallback(PVOID Context, UINT Notification, UINT_PTR Param1, UINT_PTR Param2)
Definition: usetup.c:3130
@ FILE_COPY_PAGE
Definition: usetup.h:109
@ REGISTRY_PAGE
Definition: usetup.h:110

Referenced by RunUSetup().

◆ FlushPage()

static PAGE_NUMBER FlushPage ( PINPUT_RECORD  Ir)
static

Definition at line 3994 of file usetup.c.

3995{
3997 return REBOOT_PAGE;
3998}
@ FLUSH_PAGE
Definition: usetup.h:116
@ REBOOT_PAGE
Definition: usetup.h:117

Referenced by RunUSetup().

◆ FormatPartitionPage()

static FSVOL_OP FormatPartitionPage ( _In_ PFSVOL_CONTEXT  FsVolContext,
_In_ PVOLENTRY  Volume 
)
static

Definition at line 2527 of file usetup.c.

2530{
2531 PINPUT_RECORD Ir = FsVolContext->Ir;
2532 PPARTENTRY PartEntry = Volume->PartEntry;
2533 PDISKENTRY DiskEntry = PartEntry->DiskEntry;
2534 CHAR LineBuffer[100];
2535
2536Restart:
2538 CONSOLE_Flush();
2540
2541 PartitionDescription(PartEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2542 CONSOLE_SetTextXY(6, 10, LineBuffer);
2543
2544 DiskDescription(DiskEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2546 LineBuffer);
2547
2548 while (TRUE)
2549 {
2550 if (!IsUnattendedSetup)
2551 CONSOLE_ConInKey(Ir);
2552
2553 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2554 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
2555 {
2556 if (ConfirmQuit(Ir))
2557 {
2558 FsVolContext->NextPageOnAbort = QUIT_PAGE;
2559 return FSVOL_ABORT;
2560 }
2561 goto Restart;
2562 }
2563 else if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_RETURN || IsUnattendedSetup) /* ENTER */
2564 {
2565 /*
2566 * Remove the "Press ENTER to continue" message prompt when the ENTER
2567 * key is pressed as the user wants to begin the partition formatting.
2568 */
2571
2572 return FSVOL_DOIT;
2573 }
2574 }
2575}
#define TEXT_TYPE_REGULAR
Definition: consup.h:39
@ Restart
Definition: sacdrv.h:269
@ FSVOL_DOIT
Definition: fsutil.h:166
@ FSVOL_ABORT
Definition: fsutil.h:165
VOID MUIClearStyledText(IN ULONG Page, IN INT TextID, IN INT Flags)
Definition: mui.c:399
#define TEXT_ID_FORMAT_PROMPT
Definition: mui.h:129
@ FORMAT_PARTITION_PAGE
Definition: usetup.h:103

Referenced by FsVolCallback().

◆ FsVolCallback()

static FSVOL_OP CALLBACK FsVolCallback ( _In_opt_ PVOID  Context,
_In_ FSVOLNOTIFY  FormatStatus,
_In_ ULONG_PTR  Param1,
_In_ ULONG_PTR  Param2 
)
static

HACK!!

HACK!!

Definition at line 2600 of file usetup.c.

2605{
2606 PFSVOL_CONTEXT FsVolContext = (PFSVOL_CONTEXT)Context;
2607 PINPUT_RECORD Ir = FsVolContext->Ir;
2608
2609 switch (FormatStatus)
2610 {
2611 // FIXME: Deprecate!
2613 {
2615
2616 FsVolContext->NextPageOnAbort = SELECT_PARTITION_PAGE;
2618 return FSVOL_DOIT;
2619 return FSVOL_ABORT;
2620 }
2621
2623 {
2624 switch (Param1)
2625 {
2627 {
2629 FsVolContext->NextPageOnAbort = QUIT_PAGE;
2630 break;
2631 }
2632
2634 {
2635 /* FIXME: improve the error dialog */
2636 //
2637 // Error dialog should say that we cannot find a suitable
2638 // system partition and create one on the system. At this point,
2639 // it may be nice to ask the user whether he wants to continue,
2640 // or use an external drive as the system drive/partition
2641 // (e.g. floppy, USB drive, etc...)
2642 //
2643 PopupError("The ReactOS Setup could not find a supported system partition\n"
2644 "on your system or could not create a new one. Without such a partition\n"
2645 "the Setup program cannot install ReactOS.\n"
2646 "Press ENTER to return to the partition selection list.",
2648 Ir, POPUP_WAIT_ENTER);
2649
2650 FsVolContext->NextPageOnAbort = SELECT_PARTITION_PAGE;
2651 break;
2652 }
2653
2654 default:
2655 break;
2656 }
2657 return FSVOL_ABORT;
2658 }
2659
2662 // NOTE: If needed, clear screen and flush input.
2663 return FSVOL_DOIT;
2664
2666 {
2667 if ((FSVOL_OP)Param1 == FSVOL_FORMAT)
2668 {
2669 /*
2670 * In case we just repair an existing installation, or make
2671 * an unattended setup without formatting, just go to the
2672 * file system check step.
2673 */
2674 if (RepairUpdateFlag)
2675 return FSVOL_SKIP;
2678 return FSVOL_SKIP;
2679 }
2680 return FSVOL_DOIT;
2681 }
2682
2684 return 0;
2685
2687 {
2688 PFORMAT_VOLUME_INFO FmtInfo = (PFORMAT_VOLUME_INFO)Param1;
2690
2691 // FIXME: See also FSVOLNOTIFY_PARTITIONERROR
2692 if (FmtInfo->ErrorStatus == STATUS_PARTITION_FAILURE)
2693 {
2695 FsVolContext->NextPageOnAbort = QUIT_PAGE;
2696 return FSVOL_ABORT;
2697 }
2698 else
2700 {
2701 /* FIXME: show an error dialog */
2702 // MUIDisplayError(ERROR_FORMATTING_PARTITION, Ir, POPUP_WAIT_ANY_KEY,
2703 // FmtInfo->Volume->Info.DeviceName);
2704 FsVolContext->NextPageOnAbort = QUIT_PAGE;
2705 return FSVOL_ABORT;
2706 }
2707 else
2708 if (FmtInfo->ErrorStatus == STATUS_NOT_SUPPORTED)
2709 {
2711 sizeof(Buffer),
2712 "Setup is currently unable to format a partition in %S.\n"
2713 "\n"
2714 " \x07 Press ENTER to continue Setup.\n"
2715 " \x07 Press F3 to quit Setup.",
2716 FmtInfo->FileSystemName);
2717
2721
2722 while (TRUE)
2723 {
2724 CONSOLE_ConInKey(Ir);
2725
2726 if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x00 &&
2727 Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3) /* F3 */
2728 {
2729 if (ConfirmQuit(Ir))
2730 {
2731 FsVolContext->NextPageOnAbort = QUIT_PAGE;
2732 return FSVOL_ABORT;
2733 }
2734 return FSVOL_RETRY;
2735 }
2736 else if (Ir->Event.KeyEvent.uChar.AsciiChar == VK_RETURN) /* ENTER */
2737 {
2738 return FSVOL_RETRY;
2739 }
2740 }
2741 }
2742 else if (!NT_SUCCESS(FmtInfo->ErrorStatus))
2743 {
2744 DPRINT1("FormatPartition() failed: Status 0x%08lx\n", FmtInfo->ErrorStatus);
2746 FmtInfo->Volume->Info.DeviceName);
2747 FsVolContext->NextPageOnAbort = QUIT_PAGE;
2748 return FSVOL_ABORT;
2749 }
2750 return FSVOL_RETRY;
2751 }
2752
2754 {
2755 PCHECK_VOLUME_INFO ChkInfo = (PCHECK_VOLUME_INFO)Param1;
2757
2758 if (ChkInfo->ErrorStatus == STATUS_NOT_SUPPORTED)
2759 {
2761 sizeof(Buffer),
2762 "Setup is currently unable to check a partition formatted in %S.\n"
2763 "\n"
2764 " \x07 Press ENTER to continue Setup.\n"
2765 " \x07 Press F3 to quit Setup.",
2766 ChkInfo->Volume->Info.FileSystem);
2767
2771
2772 while (TRUE)
2773 {
2774 CONSOLE_ConInKey(Ir);
2775
2776 if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x00 &&
2777 Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3) /* F3 */
2778 {
2779 if (ConfirmQuit(Ir))
2780 {
2781 FsVolContext->NextPageOnAbort = QUIT_PAGE;
2782 return FSVOL_ABORT;
2783 }
2784 return FSVOL_SKIP;
2785 }
2786 else if (Ir->Event.KeyEvent.uChar.AsciiChar == VK_RETURN) /* ENTER */
2787 {
2788 return FSVOL_SKIP;
2789 }
2790 }
2791 }
2792 else if (!NT_SUCCESS(ChkInfo->ErrorStatus))
2793 {
2794 DPRINT1("ChkdskPartition() failed: Status 0x%08lx\n", ChkInfo->ErrorStatus);
2795
2797 sizeof(Buffer),
2798 "ChkDsk detected some disk errors.\n(Status 0x%08lx).\n",
2799 ChkInfo->ErrorStatus);
2800
2803 Ir, POPUP_WAIT_ENTER);
2804 return FSVOL_SKIP;
2805 }
2806 return FSVOL_SKIP;
2807 }
2808
2810 {
2811 PFORMAT_VOLUME_INFO FmtInfo = (PFORMAT_VOLUME_INFO)Param1;
2813
2814 ASSERT((FSVOL_OP)Param2 == FSVOL_FORMAT);
2815
2816 /* Select the file system */
2817 Result = SelectFileSystemPage(FsVolContext, FmtInfo->Volume);
2818 if (Result != FSVOL_DOIT)
2819 return Result;
2820
2821 /* Display the formatting page */
2822 Result = FormatPartitionPage(FsVolContext, FmtInfo->Volume);
2823 if (Result != FSVOL_DOIT)
2824 return Result;
2825
2827 return FSVOL_DOIT;
2828 }
2829
2831 {
2832 PFORMAT_VOLUME_INFO FmtInfo = (PFORMAT_VOLUME_INFO)Param1;
2833 EndFormat(FmtInfo->ErrorStatus);
2834
2835 /* Reset the file system list */
2837 return 0;
2838 }
2839
2841 {
2842 PCHECK_VOLUME_INFO ChkInfo = (PCHECK_VOLUME_INFO)Param1;
2843
2844 ASSERT((FSVOL_OP)Param2 == FSVOL_CHECK);
2845
2846 CheckFileSystemPage(ChkInfo->Volume);
2847 StartCheck(ChkInfo);
2848 return FSVOL_DOIT;
2849 }
2850
2852 {
2853 PCHECK_VOLUME_INFO ChkInfo = (PCHECK_VOLUME_INFO)Param1;
2854 EndCheck(ChkInfo->ErrorStatus);
2855 return 0;
2856 }
2857 }
2858
2859 return 0;
2860}
@ ERROR_WRITE_PTABLE
Definition: errorcode.h:51
@ ERROR_FORMATTING_PARTITION
Definition: errorcode.h:60
VOID EndCheck(_In_ NTSTATUS Status)
Definition: fmtchk.c:150
VOID StartCheck(_Inout_ PCHECK_VOLUME_INFO ChkInfo)
Definition: fmtchk.c:127
VOID StartFormat(_Inout_ PFORMAT_VOLUME_INFO FmtInfo, _In_ PFILE_SYSTEM_ITEM SelectedFileSystem)
Definition: fmtchk.c:70
VOID EndFormat(_In_ NTSTATUS Status)
Definition: fmtchk.c:97
struct _PARTENTRY * PPARTENTRY
Definition: partlist.h:42
#define STATUS_PARTITION_FAILURE
Definition: ntstatus.h:604
@ FSVOLNOTIFY_STARTCHECK
Definition: fsutil.h:153
@ FSVOLNOTIFY_ENDQUEUE
Definition: fsutil.h:145
@ FSVOLNOTIFY_STARTSUBQUEUE
Definition: fsutil.h:146
@ FSVOLNOTIFY_ENDFORMAT
Definition: fsutil.h:151
@ FSVOLNOTIFY_STARTFORMAT
Definition: fsutil.h:150
@ FSVOLNOTIFY_STARTQUEUE
Definition: fsutil.h:144
@ FSVOLNOTIFY_ENDSUBQUEUE
Definition: fsutil.h:147
@ FSVOLNOTIFY_PARTITIONERROR
Definition: fsutil.h:149
@ FSVOLNOTIFY_CHECKERROR
Definition: fsutil.h:155
@ ChangeSystemPartition
Definition: fsutil.h:156
@ FSVOLNOTIFY_FORMATERROR
Definition: fsutil.h:152
@ FSVOLNOTIFY_ENDCHECK
Definition: fsutil.h:154
enum _FSVOL_OP FSVOL_OP
struct _FORMAT_VOLUME_INFO * PFORMAT_VOLUME_INFO
@ FSVOL_FORMAT
Definition: fsutil.h:162
@ FSVOL_CHECK
Definition: fsutil.h:163
@ FSVOL_RETRY
Definition: fsutil.h:167
@ FSVOL_SKIP
Definition: fsutil.h:168
struct _CHECK_VOLUME_INFO * PCHECK_VOLUME_INFO
#define ERROR_SYSTEM_PARTITION_NOT_FOUND
Definition: setuplib.h:190
NTSTATUS ErrorStatus
Definition: fsutil.h:191
PVOLENTRY Volume
Definition: fsutil.h:189
PFILE_SYSTEM_ITEM Selected
Definition: fslist.h:42
NTSTATUS ErrorStatus
Definition: fsutil.h:175
PVOLENTRY Volume
Definition: fsutil.h:173
PCWSTR FileSystemName
Definition: fsutil.h:178
PAGE_NUMBER NextPageOnAbort
Definition: usetup.c:2270
PINPUT_RECORD Ir
Definition: usetup.c:2269
LONG FormatPartition
Definition: setuplib.h:135
VOLINFO Info
Definition: partlist.h:47
WCHAR DeviceName[MAX_PATH]
NT device name: "\Device\HarddiskVolumeN".
Definition: volutil.h:13
WCHAR FileSystem[MAX_PATH+1]
Definition: volutil.h:17
#define STATUS_UNRECOGNIZED_VOLUME
Definition: udferr_usr.h:173
#define STRING_QUITCONTINUE
Definition: mui.h:150
static VOID CheckFileSystemPage(_In_ PVOLENTRY Volume)
Definition: usetup.c:2578
static BOOLEAN ChangeSystemPartitionPage(IN PINPUT_RECORD Ir, IN PPARTENTRY SystemPartition)
Definition: usetup.c:2316
static VOID ResetFileSystemList(VOID)
Definition: usetup.c:2359
static FSVOL_OP FormatPartitionPage(_In_ PFSVOL_CONTEXT FsVolContext, _In_ PVOLENTRY Volume)
Definition: usetup.c:2527
struct _FSVOL_CONTEXT * PFSVOL_CONTEXT
static FSVOL_OP SelectFileSystemPage(_In_ PFSVOL_CONTEXT FsVolContext, _In_ PVOLENTRY Volume)
Definition: usetup.c:2369
static PFILE_SYSTEM_LIST FileSystemList
Definition: usetup.c:87
#define POPUP_WAIT_ANY_KEY
Definition: usetup.h:122

Referenced by StartPartitionOperationsPage().

◆ GetNTOSInstallationName()

static NTSTATUS NTAPI GetNTOSInstallationName ( IN PGENERIC_LIST_ENTRY  Entry,
OUT PSTR  Buffer,
IN SIZE_T  cchBufferSize 
)
static

Definition at line 508 of file usetup.c.

512{
514 PVOLINFO VolInfo = (NtOsInstall->Volume ? &NtOsInstall->Volume->Info : NULL);
515
516 if (VolInfo && VolInfo->DriveLetter)
517 {
518 /* We have retrieved a partition that is mounted */
519 return RtlStringCchPrintfA(Buffer, cchBufferSize,
520 "%C:%S \"%S\"",
521 VolInfo->DriveLetter,
522 NtOsInstall->PathComponent,
523 NtOsInstall->InstallationName);
524 }
525 else
526 {
527 /* We failed somewhere, just show the NT path */
528 return RtlStringCchPrintfA(Buffer, cchBufferSize,
529 "%wZ \"%S\"",
530 &NtOsInstall->SystemNtPath,
531 NtOsInstall->InstallationName);
532 }
533}
PVOID NTAPI GetListEntryData(IN PGENERIC_LIST_ENTRY Entry)
Definition: genlist.c:134
NTSTRSAFEVAPI RtlStringCchPrintfA(_Out_writes_(cchDest) _Always_(_Post_z_) NTSTRSAFE_PSTR pszDest, _In_ size_t cchDest, _In_ _Printf_format_string_ NTSTRSAFE_PCSTR pszFormat,...)
Definition: ntstrsafe.h:1085
struct _NTOS_INSTALLATION * PNTOS_INSTALLATION
base of all file and directory entries
Definition: entries.h:83
WCHAR InstallationName[MAX_PATH]
Definition: osdetect.h:26
UNICODE_STRING SystemNtPath
Definition: osdetect.h:21
PVOLENTRY Volume
Definition: osdetect.h:25
PCWSTR PathComponent
Definition: osdetect.h:22
WCHAR DriveLetter
Definition: volutil.h:15

Referenced by UpgradeRepairPage().

◆ GetSettingDescription()

static NTSTATUS NTAPI GetSettingDescription ( IN PGENERIC_LIST_ENTRY  Entry,
OUT PSTR  Buffer,
IN SIZE_T  cchBufferSize 
)
static

Definition at line 497 of file usetup.c.

501{
502 return RtlStringCchPrintfA(Buffer, cchBufferSize, "%S",
504}
_Must_inspect_result_ _In_ WDFKEY _In_ PCUNICODE_STRING _Out_opt_ PUSHORT _Inout_opt_ PUNICODE_STRING Value
Definition: wdfregistry.h:413

Referenced by ComputerSettingsPage(), DeviceSettingsPage(), DisplaySettingsPage(), KeyboardSettingsPage(), LanguagePage(), and LayoutSettingsPage().

◆ HandleGenericList()

static PAGE_NUMBER HandleGenericList ( PGENERIC_LIST_UI  ListUi,
PAGE_NUMBER  nextPage,
PINPUT_RECORD  Ir 
)
static

Definition at line 1360 of file usetup.c.

1363{
1364 while (TRUE)
1365 {
1366 CONSOLE_ConInKey(Ir);
1367
1368 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1369 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_DOWN)) /* DOWN */
1370 {
1371 ScrollDownGenericList(ListUi);
1372 }
1373 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1374 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_UP)) /* UP */
1375 {
1376 ScrollUpGenericList(ListUi);
1377 }
1378 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1379 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_NEXT)) /* PAGE DOWN */
1380 {
1382 }
1383 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1384 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_PRIOR)) /* PAGE UP */
1385 {
1387 }
1388 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1389 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
1390 {
1391 if (ConfirmQuit(Ir))
1392 return QUIT_PAGE;
1393 RedrawGenericList(ListUi);
1394 }
1395 else if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_ESCAPE) /* ESC */
1396 {
1398 return nextPage; // Use some "prevPage;" instead?
1399 }
1400 else if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D) /* ENTER */
1401 {
1402 return nextPage;
1403 }
1404 else if ((Ir->Event.KeyEvent.uChar.AsciiChar > 0x60) && (Ir->Event.KeyEvent.uChar.AsciiChar < 0x7b))
1405 {
1406 /* a-z */
1408 }
1409 }
1410}
VOID RedrawGenericList(IN PGENERIC_LIST_UI ListUi)
Definition: genlist.c:511
VOID ScrollPageUpGenericList(IN PGENERIC_LIST_UI ListUi)
Definition: genlist.c:454
VOID RestoreGenericListUiState(IN PGENERIC_LIST_UI ListUi)
Definition: genlist.c:62
VOID GenericListKeyPress(IN PGENERIC_LIST_UI ListUi, IN CHAR AsciiChar)
Definition: genlist.c:525
VOID ScrollUpGenericList(IN PGENERIC_LIST_UI ListUi)
Definition: genlist.c:404
VOID ScrollDownGenericList(IN PGENERIC_LIST_UI ListUi)
Definition: genlist.c:376
VOID ScrollPageDownGenericList(IN PGENERIC_LIST_UI ListUi)
Definition: genlist.c:432
#define VK_NEXT
Definition: winuser.h:2224
#define VK_PRIOR
Definition: winuser.h:2223

Referenced by ComputerSettingsPage(), DisplaySettingsPage(), KeyboardSettingsPage(), and LayoutSettingsPage().

◆ InstallDirectoryPage()

static PAGE_NUMBER InstallDirectoryPage ( PINPUT_RECORD  Ir)
static

Definition at line 2874 of file usetup.c.

2875{
2877 ULONG Length, Pos;
2878 WCHAR c;
2879 WCHAR InstallDir[MAX_PATH];
2880
2882 {
2883 /* FIXME: show an error dialog */
2884 return QUIT_PAGE;
2885 }
2886
2887 // if (IsUnattendedSetup)
2888 if (RepairUpdateFlag)
2889 wcscpy(InstallDir, CurrentInstallation->PathComponent); // SystemNtPath
2892 else
2893 wcscpy(InstallDir, L"\\ReactOS");
2894
2895 /*
2896 * Check the validity of the predefined 'InstallDir'. If we are either
2897 * in unattended setup or in update/repair mode, and the installation path
2898 * is valid, just perform the installation. Otherwise (either in the case
2899 * of an invalid path, or we are in regular setup), display the UI and allow
2900 * the user to specify a new installation path.
2901 */
2903 {
2904 /* Check for the validity of the installation directory and pop up
2905 * an error if it is not the case. Then the user can fix it. */
2906 if (IsValidInstallDirectory(InstallDir))
2907 goto InitInstallDir;
2908
2910 }
2911
2912 Length = wcslen(InstallDir);
2913 Pos = Length;
2914
2916 CONSOLE_SetInputTextXY(8, 11, 51, InstallDir);
2917 CONSOLE_SetCursorXY(8 + Pos, 11);
2919
2920 while (TRUE)
2921 {
2922 CONSOLE_ConInKey(Ir);
2923
2924 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2925 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
2926 {
2928
2929 if (ConfirmQuit(Ir))
2930 return QUIT_PAGE;
2932 }
2933 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2934 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_DELETE)) /* DEL */
2935 {
2936 if (Pos < Length)
2937 {
2938 memmove(&InstallDir[Pos],
2939 &InstallDir[Pos + 1],
2940 (Length - Pos - 1) * sizeof(WCHAR));
2941 InstallDir[Length - 1] = UNICODE_NULL;
2942
2943 Length--;
2944 CONSOLE_SetInputTextXY(8, 11, 51, InstallDir);
2945 CONSOLE_SetCursorXY(8 + Pos, 11);
2946 }
2947 }
2948 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2949 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_HOME)) /* HOME */
2950 {
2951 Pos = 0;
2952 CONSOLE_SetCursorXY(8 + Pos, 11);
2953 }
2954 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2955 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_END)) /* END */
2956 {
2957 Pos = Length;
2958 CONSOLE_SetCursorXY(8 + Pos, 11);
2959 }
2960 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2961 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_LEFT)) /* LEFT */
2962 {
2963 if (Pos > 0)
2964 {
2965 Pos--;
2966 CONSOLE_SetCursorXY(8 + Pos, 11);
2967 }
2968 }
2969 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2970 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_RIGHT)) /* RIGHT */
2971 {
2972 if (Pos < Length)
2973 {
2974 Pos++;
2975 CONSOLE_SetCursorXY(8 + Pos, 11);
2976 }
2977 }
2978 else if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_ESCAPE) /* ESC */
2979 {
2980 /* Erase the whole line */
2981 *InstallDir = UNICODE_NULL;
2982 Pos = Length = 0;
2983 CONSOLE_SetInputTextXY(8, 11, 51, InstallDir);
2984 CONSOLE_SetCursorXY(8 + Pos, 11);
2985 }
2986 else if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D) /* ENTER */
2987 {
2989
2990 /* Check for the validity of the installation directory and pop up
2991 * an error if it is not the case. Then the user can fix it. */
2992 if (IsValidInstallDirectory(InstallDir))
2993 goto InitInstallDir;
2994
2997 }
2998 else if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x08) /* BACKSPACE */
2999 {
3000 if (Pos > 0)
3001 {
3002 if (Pos < Length)
3003 memmove(&InstallDir[Pos - 1],
3004 &InstallDir[Pos],
3005 (Length - Pos) * sizeof(WCHAR));
3006 InstallDir[Length - 1] = UNICODE_NULL;
3007
3008 Pos--;
3009 Length--;
3010 CONSOLE_SetInputTextXY(8, 11, 51, InstallDir);
3011 CONSOLE_SetCursorXY(8 + Pos, 11);
3012 }
3013 }
3014 else if (isprint(Ir->Event.KeyEvent.uChar.AsciiChar))
3015 {
3016 if (Length < 50)
3017 {
3018 /* Only accept valid characters for the installation path */
3021 {
3022 if (Pos < Length)
3023 memmove(&InstallDir[Pos + 1],
3024 &InstallDir[Pos],
3025 (Length - Pos) * sizeof(WCHAR));
3026 InstallDir[Length + 1] = UNICODE_NULL;
3027 InstallDir[Pos] = c;
3028
3029 Pos++;
3030 Length++;
3031 CONSOLE_SetInputTextXY(8, 11, 51, InstallDir);
3032 CONSOLE_SetCursorXY(8 + Pos, 11);
3033 }
3034 }
3035 }
3036 }
3037
3038InitInstallDir:
3040 if (!NT_SUCCESS(Status))
3041 {
3042 DPRINT1("InitDestinationPaths() failed: Status 0x%lx\n", Status);
3044 return QUIT_PAGE;
3045 }
3046
3047 /*
3048 * Check whether the user attempts to install ReactOS within the
3049 * installation source directory, or in a subdirectory thereof.
3050 * If so, fail with an error.
3051 */
3053 {
3056 }
3057
3058 return PREPARE_COPY_PAGE;
3059}
#define isprint(c)
Definition: acclib.h:73
VOID CONSOLE_SetInputTextXY(IN SHORT x, IN SHORT y, IN SHORT len, IN LPCWSTR Text)
Definition: consup.c:357
VOID CONSOLE_SetCursorXY(IN SHORT x, IN SHORT y)
Definition: consup.c:227
VOID CONSOLE_SetCursorType(IN BOOL bInsert, IN BOOL bVisible)
Definition: consup.c:214
ush Pos
Definition: deflate.h:92
@ ERROR_SOURCE_DIR
Definition: errorcode.h:21
@ ERROR_DIRECTORY_NAME
Definition: errorcode.h:56
@ ERROR_NO_BUILD_PATH
Definition: errorcode.h:19
const GLubyte * c
Definition: glext.h:8905
_CRTIMP size_t __cdecl wcslen(_In_z_ const wchar_t *_Str)
#define c
Definition: ke_i.h:80
if(dx< 0)
Definition: linetemp.h:194
#define memmove(s1, s2, n)
Definition: mkisofs.h:881
NTSYSAPI BOOLEAN NTAPI RtlPrefixUnicodeString(IN PUNICODE_STRING String1, IN PUNICODE_STRING String2, IN BOOLEAN CaseInSensitive)
#define UNICODE_NULL
_In_ ULONG _In_ ULONG _In_ ULONG Length
Definition: ntddpcm.h:102
_CRTIMP wchar_t *__cdecl wcscpy(_Out_writes_z_(_String_length_(_Source)+1) wchar_t *_Dest, _In_z_ const wchar_t *_Source)
NTSTATUS NTAPI InitDestinationPaths(_Inout_ PUSETUP_DATA pSetupData, _In_ PCWSTR InstallationDir, _In_ PVOLENTRY Volume)
Definition: setuplib.c:863
BOOLEAN NTAPI IsValidInstallDirectory(_In_ PCWSTR InstallDir)
Verify whether the given directory is suitable for ReactOS installation. Each path component must be ...
Definition: setuplib.c:778
#define IS_VALID_INSTALL_PATH_CHAR(c)
Defines the class of characters valid for the installation directory.
Definition: setuplib.h:208
UNICODE_STRING SourcePath
Definition: setuplib.h:105
WCHAR InstallationDirectory[MAX_PATH]
Definition: setuplib.h:159
UNICODE_STRING DestinationPath
Definition: setuplib.h:125
#define InstallVolume
Definition: usetup.c:49
static PPARTENTRY InstallPartition
Definition: usetup.c:47
static PNTOS_INSTALLATION CurrentInstallation
Definition: usetup.c:91
@ PREPARE_COPY_PAGE
Definition: usetup.h:107
#define VK_LEFT
Definition: winuser.h:2227
#define VK_RIGHT
Definition: winuser.h:2229
#define VK_DELETE
Definition: winuser.h:2236

Referenced by RunUSetup().

◆ InstallIntroPage()

static PAGE_NUMBER InstallIntroPage ( PINPUT_RECORD  Ir)
static

Definition at line 1096 of file usetup.c.

1097{
1098 if (RepairUpdateFlag)
1099 {
1100#if 1 /* Old code that looks good */
1101
1102 // return SELECT_PARTITION_PAGE;
1103 return DEVICE_SETTINGS_PAGE;
1104
1105#else /* Possible new code? */
1106
1107 return DEVICE_SETTINGS_PAGE;
1108 // return SCSI_CONTROLLER_PAGE;
1109
1110#endif
1111 }
1112
1114 return SELECT_PARTITION_PAGE;
1115
1117
1118 while (TRUE)
1119 {
1120 CONSOLE_ConInKey(Ir);
1121
1122 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1123 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
1124 {
1125 if (ConfirmQuit(Ir))
1126 return QUIT_PAGE;
1127 break;
1128 }
1129 else if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D) /* ENTER */
1130 {
1131 return UPGRADE_REPAIR_PAGE;
1132 }
1133 }
1134
1135 return INSTALL_INTRO_PAGE;
1136}
@ UPGRADE_REPAIR_PAGE
Definition: usetup.h:87
@ INSTALL_INTRO_PAGE
Definition: usetup.h:81

Referenced by RunUSetup().

◆ IsMediumLargeEnough()

static BOOLEAN IsMediumLargeEnough ( _In_ ULONGLONG  SizeInBytes)
static

Definition at line 1518 of file usetup.c.

1520{
1521 /* Retrieve the maximum size in MB (rounded up) */
1522 ULONGLONG SizeInMB = RoundingDivide(SizeInBytes, MB);
1523
1524 /* Check the medium size */
1526 {
1527 DPRINT1("Partition/Volume is too small (size: %I64u MB), required space is %lu MB\n",
1529 return FALSE;
1530 }
1531 return TRUE;
1532}
ULONG RequiredPartitionDiskSpace
Definition: setuplib.h:158

Referenced by SelectPartitionPage().

◆ KeyboardSettingsPage()

static PAGE_NUMBER KeyboardSettingsPage ( PINPUT_RECORD  Ir)
static

Definition at line 1476 of file usetup.c.

1477{
1478 GENERIC_LIST_UI ListUi;
1480
1482 DrawGenericList(&ListUi,
1483 2, 18,
1484 xScreen - 3,
1485 yScreen - 3);
1486
1487 return HandleGenericList(&ListUi, DEVICE_SETTINGS_PAGE, Ir);
1488}

Referenced by RunUSetup().

◆ LanguagePage()

static PAGE_NUMBER LanguagePage ( PINPUT_RECORD  Ir)
static

Definition at line 675 of file usetup.c.

676{
677 GENERIC_LIST_UI ListUi;
678 PCWSTR NewLanguageId;
679 BOOL RefreshPage = FALSE;
680
681 /* Initialize the computer settings list */
683 {
686 {
687 PopupError("Setup failed to initialize available translations", NULL, NULL, POPUP_WAIT_NONE);
688 return WELCOME_PAGE;
689 }
690 }
691
694
695 /* Load the font */
698
699 /*
700 * If there is no language or just a single one in the list,
701 * skip the language selection process altogether.
702 */
704 {
706 return WELCOME_PAGE;
707 }
708
710 DrawGenericList(&ListUi,
711 2, 18,
712 xScreen - 3,
713 yScreen - 3);
714
716
718
719 while (TRUE)
720 {
722
723 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
724 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_DOWN)) /* DOWN */
725 {
726 ScrollDownGenericList(&ListUi);
727 RefreshPage = TRUE;
728 }
729 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
730 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_UP)) /* UP */
731 {
732 ScrollUpGenericList(&ListUi);
733 RefreshPage = TRUE;
734 }
735 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
736 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_NEXT)) /* PAGE DOWN */
737 {
739 RefreshPage = TRUE;
740 }
741 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
742 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_PRIOR)) /* PAGE UP */
743 {
745 RefreshPage = TRUE;
746 }
747 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
748 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
749 {
750 if (ConfirmQuit(Ir))
751 return QUIT_PAGE;
752 RedrawGenericList(&ListUi);
753 }
754 else if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D) /* ENTER */
755 {
757
760
762
764 {
766 }
767
768 /* Load the font */
770
771 return WELCOME_PAGE;
772 }
773 else if ((Ir->Event.KeyEvent.uChar.AsciiChar > 0x60) && (Ir->Event.KeyEvent.uChar.AsciiChar < 0x7b))
774 {
775 /* a-z */
777 RefreshPage = TRUE;
778 }
779
780 if (RefreshPage)
781 {
783
784 NewLanguageId =
786
787 if (wcscmp(SelectedLanguageId, NewLanguageId))
788 {
789 /* Clear the language page */
791
792 SelectedLanguageId = NewLanguageId;
793
794 /* Load the font */
796
797 /* Redraw the list */
798 DrawGenericList(&ListUi,
799 2, 18,
800 xScreen - 3,
801 yScreen - 3);
802
803 /* Redraw language selection page in native language */
805 }
806
807 RefreshPage = FALSE;
808 }
809 }
810
811 return WELCOME_PAGE;
812}
ULONG GetDefaultLanguageIndex(VOID)
Definition: settings.c:1098
PGENERIC_LIST CreateLanguageList(IN HINF InfFile, OUT PWSTR DefaultLanguage)
Definition: settings.c:1159
struct _GENENTRY * PGENENTRY
_Check_return_ long __cdecl wcstol(_In_z_ const wchar_t *_Str, _Out_opt_ _Deref_post_z_ wchar_t **_EndPtr, _In_ int _Radix)
USHORT LANGID
Definition: mui.h:9
ULONG NTAPI GetNumberOfListEntries(IN PGENERIC_LIST List)
Definition: genlist.c:149
PGENERIC_LIST_ENTRY NTAPI GetCurrentListEntry(IN PGENERIC_LIST List)
Definition: genlist.c:102
_Check_return_ _CRTIMP int __cdecl wcscmp(_In_z_ const wchar_t *_Str1, _In_z_ const wchar_t *_Str2)
PGENERIC_LIST LanguageList
Definition: setuplib.h:144
LANGID LanguageId
Definition: setuplib.h:156
VOID ScrollToPositionGenericList(IN PGENERIC_LIST_UI ListUi, IN ULONG uIndex)
Definition: genlist.c:476
VOID SetConsoleCodePage(VOID)
Definition: mui.c:537
VOID MUIClearPage(IN ULONG page)
Definition: mui.c:142
static WCHAR DefaultLanguage[20]
Definition: usetup.c:68
static VOID UpdateKBLayout(VOID)
Definition: usetup.c:460
@ WELCOME_PAGE
Definition: usetup.h:79
@ LANGUAGE_PAGE
Definition: usetup.h:78

Referenced by RunUSetup().

◆ LayoutSettingsPage()

static PAGE_NUMBER LayoutSettingsPage ( PINPUT_RECORD  Ir)
static

Definition at line 1502 of file usetup.c.

1503{
1504 GENERIC_LIST_UI ListUi;
1506
1508 DrawGenericList(&ListUi,
1509 2, 18,
1510 xScreen - 3,
1511 yScreen - 3);
1512
1513 return HandleGenericList(&ListUi, DEVICE_SETTINGS_PAGE, Ir);
1514}

Referenced by RunUSetup().

◆ LicensePage()

static PAGE_NUMBER LicensePage ( PINPUT_RECORD  Ir)
static

Definition at line 872 of file usetup.c.

873{
875
876 while (TRUE)
877 {
879
880 if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D) /* ENTER */
881 {
882 return WELCOME_PAGE;
883 }
884 }
885
886 return LICENSE_PAGE;
887}
@ LICENSE_PAGE
Definition: usetup.h:80

Referenced by RunUSetup().

◆ NtProcessStartup()

VOID NTAPI NtProcessStartup ( PPEB  Peb)

Definition at line 4210 of file usetup.c.

4211{
4214
4216
4218
4220
4221 Status = RunUSetup();
4222
4223 if (NT_SUCCESS(Status))
4224 {
4225 /*
4226 * Avoid a bugcheck if RunUSetup() finishes too quickly by implementing
4227 * a protective waiting.
4228 * This wait is needed because, since we are started as SMSS.EXE,
4229 * the NT kernel explicitly waits 5 seconds for the initial process
4230 * SMSS.EXE to initialize (as a protective measure), and otherwise
4231 * bugchecks with the code SESSION5_INITIALIZATION_FAILED.
4232 */
4233 Time.QuadPart += 50000000;
4235 }
4236 else
4237 {
4238 /* The installer failed to start: raise a hard error (crash the system/BSOD) */
4240 0, 0, NULL, 0, NULL);
4241 }
4242
4244}
PPEB Peb
Definition: dllmain.c:27
NTSTATUS NTAPI NtRaiseHardError(IN NTSTATUS ErrorStatus, IN ULONG NumberOfParameters, IN ULONG UnicodeStringParameterMask, IN PULONG_PTR Parameters, IN ULONG ValidResponseOptions, OUT PULONG Response)
Definition: harderr.c:551
static PLARGE_INTEGER Time
Definition: time.c:105
NTSYSAPI PRTL_USER_PROCESS_PARAMETERS NTAPI RtlNormalizeProcessParams(_In_ PRTL_USER_PROCESS_PARAMETERS ProcessParameters)
NTSTATUS NTAPI NtTerminateProcess(HANDLE ProcessHandle, LONG ExitStatus)
#define NtCurrentProcess()
Definition: nt_native.h:1657
NTSTATUS NTAPI NtDelayExecution(IN BOOLEAN Alertable, IN PLARGE_INTEGER DelayInterval)
Definition: wait.c:876
NTSTATUS NTAPI NtQuerySystemTime(OUT PLARGE_INTEGER SystemTime)
Definition: time.c:569
#define STATUS_SYSTEM_PROCESS_TERMINATED
Definition: ntstatus.h:670
PVOID ProcessHeap
Definition: ntddk_ex.h:249
PRTL_USER_PROCESS_PARAMETERS ProcessParameters
Definition: btrfs_drv.h:1913
LONGLONG QuadPart
Definition: typedefs.h:114
HANDLE ProcessHeap
Definition: usetup.c:42
NTSTATUS RunUSetup(VOID)
Definition: usetup.c:4005

◆ PopupError()

VOID PopupError ( PCCH  Text,
PCCH  Status,
PINPUT_RECORD  Ir,
ULONG  WaitEvent 
)

Definition at line 260 of file usetup.c.

264{
265 SHORT yTop;
266 SHORT xLeft;
267 COORD coPos;
268 DWORD Written;
270 ULONG MaxLength;
271 ULONG Lines;
272 PCHAR p;
273 PCCH pnext;
274 BOOLEAN LastLine;
275 SHORT Width;
277
278 /* Count text lines and longest line */
279 MaxLength = 0;
280 Lines = 0;
281 pnext = Text;
282
283 while (TRUE)
284 {
285 p = strchr(pnext, '\n');
286
287 if (p == NULL)
288 {
289 Length = strlen(pnext);
290 LastLine = TRUE;
291 }
292 else
293 {
294 Length = (ULONG)(p - pnext);
295 LastLine = FALSE;
296 }
297
298 Lines++;
299
300 if (Length > MaxLength)
301 MaxLength = Length;
302
303 if (LastLine)
304 break;
305
306 pnext = p + 1;
307 }
308
309 /* Check length of status line */
310 if (Status != NULL)
311 {
313
314 if (Length > MaxLength)
315 MaxLength = Length;
316 }
317
318 Width = MaxLength + 4;
319 Height = Lines + 2;
320
321 if (Status != NULL)
322 Height += 2;
323
324 yTop = (yScreen - Height) / 2;
325 xLeft = (xScreen - Width) / 2;
326
327
328 /* Set screen attributes */
329 coPos.X = xLeft;
330 for (coPos.Y = yTop; coPos.Y < yTop + Height; coPos.Y++)
331 {
334 Width,
335 coPos,
336 &Written);
337 }
338
339 DrawBox(xLeft, yTop, Width, Height);
340
341 /* Print message text */
342 coPos.Y = yTop + 1;
343 pnext = Text;
344 while (TRUE)
345 {
346 p = strchr(pnext, '\n');
347
348 if (p == NULL)
349 {
350 Length = strlen(pnext);
351 LastLine = TRUE;
352 }
353 else
354 {
355 Length = (ULONG)(p - pnext);
356 LastLine = FALSE;
357 }
358
359 if (Length != 0)
360 {
361 coPos.X = xLeft + 2;
363 pnext,
364 Length,
365 coPos,
366 &Written);
367 }
368
369 if (LastLine)
370 break;
371
372 coPos.Y++;
373 pnext = p + 1;
374 }
375
376 /* Print separator line and status text */
377 if (Status != NULL)
378 {
379 coPos.Y = yTop + Height - 3;
380 coPos.X = xLeft;
383 1,
384 coPos,
385 &Written);
386
387 coPos.X = xLeft + 1;
389 CharHorizontalLine, // '-',
390 Width - 2,
391 coPos,
392 &Written);
393
394 coPos.X = xLeft + Width - 1;
397 1,
398 coPos,
399 &Written);
400
401 coPos.Y++;
402 coPos.X = xLeft + 2;
404 Status,
405 min(strlen(Status), (SIZE_T)Width - 4),
406 coPos,
407 &Written);
408 }
409
410 if (WaitEvent == POPUP_WAIT_NONE)
411 return;
412
413 while (TRUE)
414 {
416
417 if (WaitEvent == POPUP_WAIT_ANY_KEY ||
418 Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D)
419 {
420 return;
421 }
422 }
423}
ACPI_SIZE strlen(const char *String)
Definition: utclib.c:269
char * strchr(const char *String, int ch)
Definition: utclib.c:501
BOOL WINAPI WriteConsoleOutputCharacterA(HANDLE hConsoleOutput, IN LPCSTR lpCharacter, IN DWORD nLength, IN COORD dwWriteCoord, OUT LPDWORD lpNumberOfCharsWritten)
Definition: console.c:407
BOOL WINAPI FillConsoleOutputAttribute(IN HANDLE hConsoleOutput, IN WORD wAttribute, IN DWORD nLength, IN COORD dwWriteCoord, OUT LPDWORD lpNumberOfAttrsWritten)
Definition: console.c:525
#define FOREGROUND_RED
Definition: blue.h:63
char * Text
Definition: combotst.c:136
#define BACKGROUND_WHITE
Definition: consup.h:31
GLfloat GLfloat p
Definition: glext.h:8902
CONST CHAR * PCCH
Definition: ntbasedef.h:400
short SHORT
Definition: pedump.c:59
ULONG_PTR SIZE_T
Definition: typedefs.h:80
char * PCHAR
Definition: typedefs.h:51
CHAR CharLeftHorizLineAndVertLine
Definition: mui.c:46
CHAR CharVertLineAndRightHorizLine
Definition: mui.c:45
static VOID DrawBox(IN SHORT xLeft, IN SHORT yTop, IN SHORT Width, IN SHORT Height)
Definition: usetup.c:170

Referenced by BootLoaderHardDiskPage(), BootLoaderRemovableDiskPage(), FsVolCallback(), LanguagePage(), MUIClearPage(), MUIDisplayErrorV(), MUIDisplayPage(), MUIGetString(), and SelectPartitionPage().

◆ PrepareCopyPage()

static PAGE_NUMBER PrepareCopyPage ( PINPUT_RECORD  Ir)
static

Definition at line 3076 of file usetup.c.

3077{
3078 // ERROR_NUMBER ErrorNumber;
3080
3082
3083 /* ErrorNumber = */ Success = PrepareFileCopy(&USetupData, NULL);
3084 if (/*ErrorNumber != ERROR_SUCCESS*/ !Success)
3085 {
3086 // MUIDisplayError(ErrorNumber, Ir, POPUP_WAIT_ENTER);
3087 return QUIT_PAGE;
3088 }
3089
3090 return FILE_COPY_PAGE;
3091}
BOOLEAN NTAPI PrepareFileCopy(IN OUT PUSETUP_DATA pSetupData, IN PFILE_COPY_STATUS_ROUTINE StatusRoutine OPTIONAL)
Definition: install.c:685
@ Success
Definition: eventcreate.c:712

Referenced by RunUSetup().

◆ PrintString()

static VOID PrintString ( IN PCSTR  fmt,
  ... 
)
static

Definition at line 151 of file usetup.c.

152{
153 CHAR buffer[512];
154 va_list ap;
157
158 va_start(ap, fmt);
160 va_end(ap);
161
166}
char * va_list
Definition: acmsvcex.h:78
#define va_end(ap)
Definition: acmsvcex.h:90
#define va_start(ap, A)
Definition: acmsvcex.h:91
@ AnsiString
Definition: dnslib.h:19
GLuint buffer
Definition: glext.h:5915
int __cdecl vsprintf(char *_Dest, const char *_Format, va_list _Args)
Definition: sprintf.c:733
NTSTATUS NTAPI NtDisplayString(PUNICODE_STRING String)
NTSYSAPI NTSTATUS NTAPI RtlAnsiStringToUnicodeString(PUNICODE_STRING DestinationString, PANSI_STRING SourceString, BOOLEAN AllocateDestinationString)
NTSYSAPI VOID NTAPI RtlInitAnsiString(PANSI_STRING DestinationString, PCSZ SourceString)
Definition: dsound.c:943
void int int ULONGLONG int va_list * ap
Definition: winesup.h:36

Referenced by RunUSetup().

◆ ProgressCountdown()

static VOID ProgressCountdown ( IN PINPUT_RECORD  Ir,
IN LONG  TimeOut 
)
static

Definition at line 3795 of file usetup.c.

3798{
3800 ULONG StartTime, BarWidth, TimerDiv;
3801 LONG TimeElapsed;
3802 LONG TimerValue, OldTimerValue;
3805 BOOLEAN RefreshProgress = TRUE;
3806
3807 /* Bail out if the timeout is already zero */
3808 if (TimeOut <= 0)
3809 return;
3810
3811 /* Create the timeout progress bar and set it up */
3813 26,
3814 xScreen - 13,
3815 yScreen - 20,
3816 10,
3817 24,
3818 TRUE,
3820 0,
3821 NULL,
3824
3825 BarWidth = max(1, ProgressBar->Width);
3826 TimerValue = TimeOut * BarWidth;
3827 ProgressSetStepCount(ProgressBar, TimerValue);
3828
3830 CONSOLE_Flush();
3831
3832 TimerDiv = 1000 / BarWidth;
3833 TimerDiv = max(1, TimerDiv);
3834 OldTimerValue = TimerValue;
3835 while (TRUE)
3836 {
3837 /* Decrease the timer */
3838
3839 /*
3840 * Compute how much time the previous operations took.
3841 * This allows us in particular to take account for any time
3842 * elapsed if something slowed down.
3843 */
3844 TimeElapsed = NtGetTickCount() - StartTime;
3845 if (TimeElapsed >= TimerDiv)
3846 {
3847 /* Increase StartTime by steps of 1 / ProgressBar->Width seconds */
3848 TimeElapsed /= TimerDiv;
3849 StartTime += (TimerDiv * TimeElapsed);
3850
3851 if (TimeElapsed <= TimerValue)
3852 TimerValue -= TimeElapsed;
3853 else
3854 TimerValue = 0;
3855
3856 RefreshProgress = TRUE;
3857 }
3858
3859 if (RefreshProgress)
3860 {
3861 ProgressSetStep(ProgressBar, OldTimerValue - TimerValue);
3862 RefreshProgress = FALSE;
3863 }
3864
3865 /* Stop when the timer reaches zero */
3866 if (TimerValue <= 0)
3867 break;
3868
3869 /* Check for user key presses */
3870
3871 /*
3872 * If the timer is used, use a passive wait of maximum 1 second
3873 * while monitoring for incoming console input events, so that
3874 * we are still able to display the timing count.
3875 */
3876
3877 /* Wait a maximum of 1 second for input events */
3878 TimeElapsed = NtGetTickCount() - StartTime;
3879 if (TimeElapsed < TimerDiv)
3880 {
3881 /* Convert the time to NT format */
3882 Timeout.QuadPart = (TimerDiv - TimeElapsed) * -10000LL;
3884 }
3885 else
3886 {
3888 }
3889
3890 /* Check whether the input event has been signaled, or a timeout happened */
3891 if (Status == STATUS_TIMEOUT)
3892 {
3893 continue;
3894 }
3895 if (Status != STATUS_WAIT_0)
3896 {
3897 /* An error happened, bail out */
3898 DPRINT1("NtWaitForSingleObject() failed, Status 0x%08lx\n", Status);
3899 break;
3900 }
3901
3902 /* Check for an ENTER key press */
3903 while (CONSOLE_ConInKeyPeek(Ir))
3904 {
3905 if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D) /* ENTER */
3906 {
3907 /* Found it, stop waiting */
3908 goto Exit;
3909 }
3910 }
3911 }
3912
3913Exit:
3914 /* Destroy the progress bar and quit */
3916}
VOID ProgressSetStep(IN PPROGRESSBAR Bar, IN ULONG Step)
Definition: progress.c:368
PPROGRESSBAR CreateProgressBarEx(IN SHORT Left, IN SHORT Top, IN SHORT Right, IN SHORT Bottom, IN SHORT TextTop, IN SHORT TextRight, IN BOOLEAN DoubleEdge, IN SHORT ProgressColour, IN ULONG StepCount, IN PCSTR DescriptionText OPTIONAL, IN PCSTR ProgressFormatText OPTIONAL, IN PUPDATE_PROGRESS UpdateProgressProc OPTIONAL)
Definition: progress.c:272
#define BACKGROUND_BLUE
Definition: blue.h:65
BOOLEAN CONSOLE_ConInKeyPeek(OUT PINPUT_RECORD Buffer)
Definition: consup.c:89
HANDLE StdInput
Definition: consup.c:36
#define STATUS_TIMEOUT
Definition: d3dkmdt.h:49
static PPROGRESSBAR ProgressBar
Definition: fmtchk.c:17
static LARGE_INTEGER StartTime
Definition: sys_arch.c:13
NTSYSAPI NTSTATUS NTAPI NtWaitForSingleObject(IN HANDLE hObject, IN BOOLEAN bAlertable, IN PLARGE_INTEGER Timeout)
#define STATUS_WAIT_0
Definition: ntstatus.h:237
long LONG
Definition: pedump.c:60
static ULONG Timeout
Definition: ping.c:61
#define NtGetTickCount
Definition: rtlp.h:163
static void Exit(void)
Definition: sock.c:1330
SHORT Width
Definition: progress.h:48
#define max(a, b)
Definition: svc.c:63
#define STRING_REBOOTPROGRESSBAR
Definition: mui.h:188
static BOOLEAN NTAPI ProgressTimeOutStringHandler(IN PPROGRESSBAR Bar, IN BOOLEAN AlwaysUpdate, OUT PSTR Buffer, IN SIZE_T cchBufferSize)
Definition: usetup.c:3748

Referenced by QuitPage(), and SuccessPage().

◆ ProgressTimeOutStringHandler()

static BOOLEAN NTAPI ProgressTimeOutStringHandler ( IN PPROGRESSBAR  Bar,
IN BOOLEAN  AlwaysUpdate,
OUT PSTR  Buffer,
IN SIZE_T  cchBufferSize 
)
static

Definition at line 3748 of file usetup.c.

3753{
3754 ULONG OldProgress = Bar->Progress;
3755
3756 if (Bar->StepCount == 0)
3757 {
3758 Bar->Progress = 0;
3759 }
3760 else
3761 {
3762 Bar->Progress = Bar->StepCount - Bar->CurrentStep;
3763 }
3764
3765 /* Build the progress string if it has changed */
3766 if (Bar->ProgressFormatText &&
3767 (AlwaysUpdate || (Bar->Progress != OldProgress)))
3768 {
3769 RtlStringCchPrintfA(Buffer, cchBufferSize,
3770 Bar->ProgressFormatText, Bar->Progress / max(1, Bar->Width) + 1);
3771
3772 return TRUE;
3773 }
3774
3775 return FALSE;
3776}
void Bar(void)
Definition: terminate.cpp:70

Referenced by ProgressCountdown().

◆ QuitPage()

static PAGE_NUMBER QuitPage ( PINPUT_RECORD  Ir)
static

Definition at line 3932 of file usetup.c.

3933{
3935
3936 /* Destroy the NTOS installations list */
3937 if (NtOsInstallsList != NULL)
3938 {
3941 }
3942
3943 /* Destroy the partition list */
3944 if (PartitionList != NULL)
3945 {
3948 }
3949
3951
3952 /* Wait for maximum 15 seconds or an ENTER key before quitting */
3953 ProgressCountdown(Ir, 15);
3954 return FLUSH_PAGE;
3955}
VOID NTAPI DestroyGenericList(IN OUT PGENERIC_LIST List, IN BOOLEAN FreeData)
Definition: genlist.c:38
VOID NTAPI DestroyPartitionList(IN PPARTLIST List)
Definition: partlist.c:2074
#define STRING_REBOOTCOMPUTER2
Definition: mui.h:164
static VOID ProgressCountdown(IN PINPUT_RECORD Ir, IN LONG TimeOut)
Definition: usetup.c:3795
static PGENERIC_LIST NtOsInstallsList
Definition: usetup.c:92

Referenced by RunUSetup().

◆ RegistryPage()

static PAGE_NUMBER RegistryPage ( PINPUT_RECORD  Ir)
static

Definition at line 3373 of file usetup.c.

3374{
3375 ULONG Error;
3376
3378
3382 InstallVolume->Info.DriveLetter,
3385 &s_SubstSettings);
3386 if (Error != ERROR_SUCCESS)
3387 {
3389 return QUIT_PAGE;
3390 }
3391 else
3392 {
3395 }
3396}
BOOL Error
Definition: chkdsk.c:66
#define ERROR_SUCCESS
Definition: deptool.c:10
ERROR_NUMBER NTAPI UpdateRegistry(IN OUT PUSETUP_DATA pSetupData, IN BOOLEAN RepairUpdateFlag, IN PPARTLIST PartitionList, IN WCHAR DestinationDriveLetter, IN PCWSTR SelectedLanguageId, IN PREGISTRY_STATUS_ROUTINE StatusRoutine OPTIONAL, IN PFONTSUBSTSETTINGS SubstSettings OPTIONAL)
Definition: setuplib.c:1154
#define STRING_DONE
Definition: mui.h:163
static VOID __cdecl RegistryStatus(IN REGISTRY_STATUS RegStatus,...)
Definition: usetup.c:3330

Referenced by RunUSetup().

◆ RegistryStatus()

static VOID __cdecl RegistryStatus ( IN REGISTRY_STATUS  RegStatus,
  ... 
)
static

Definition at line 3330 of file usetup.c.

3331{
3332 /* WARNING: Please keep this lookup table in sync with the resources! */
3333 static const UINT StringIDs[] =
3334 {
3335 STRING_DONE, /* Success */
3336 STRING_REGHIVEUPDATE, /* RegHiveUpdate */
3337 STRING_IMPORTFILE, /* ImportRegHive */
3338 STRING_DISPLAYSETTINGSUPDATE, /* DisplaySettingsUpdate */
3339 STRING_LOCALESETTINGSUPDATE, /* LocaleSettingsUpdate */
3340 STRING_ADDKBLAYOUTS, /* KeybLayouts */
3341 STRING_KEYBOARDSETTINGSUPDATE, /* KeybSettingsUpdate */
3342 STRING_CODEPAGEINFOUPDATE, /* CodePageInfoUpdate */
3343 };
3344
3345 va_list args;
3346
3347 if (RegStatus < ARRAYSIZE(StringIDs))
3348 {
3349 va_start(args, RegStatus);
3350 CONSOLE_SetStatusTextV(MUIGetString(StringIDs[RegStatus]), args);
3351 va_end(args);
3352 }
3353 else
3354 {
3355 CONSOLE_SetStatusText("Unknown status %d", RegStatus);
3356 }
3357}
VOID CONSOLE_SetStatusTextV(IN LPCSTR fmt, IN va_list args)
Definition: consup.c:471
#define args
Definition: format.c:66
Definition: match.c:390
#define STRING_KEYBOARDSETTINGSUPDATE
Definition: mui.h:161
#define STRING_CODEPAGEINFOUPDATE
Definition: mui.h:162
#define STRING_LOCALESETTINGSUPDATE
Definition: mui.h:160
#define STRING_IMPORTFILE
Definition: mui.h:158
#define STRING_ADDKBLAYOUTS
Definition: mui.h:187
#define STRING_DISPLAYSETTINGSUPDATE
Definition: mui.h:159
#define STRING_REGHIVEUPDATE
Definition: mui.h:157

Referenced by RegistryPage().

◆ RepairIntroPage()

static PAGE_NUMBER RepairIntroPage ( PINPUT_RECORD  Ir)
static

Definition at line 903 of file usetup.c.

904{
906
907 while (TRUE)
908 {
910
911 if (Ir->Event.KeyEvent.uChar.AsciiChar == 0x0D) /* ENTER */
912 {
913 return REBOOT_PAGE;
914 }
915 else if (toupper(Ir->Event.KeyEvent.uChar.AsciiChar) == 'U') /* U */
916 {
918 return INSTALL_INTRO_PAGE;
919 }
920 else if (toupper(Ir->Event.KeyEvent.uChar.AsciiChar) == 'R') /* R */
921 {
922 return RECOVERY_PAGE;
923 }
924 else if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_ESCAPE) /* ESC */
925 {
926 return WELCOME_PAGE;
927 }
928 }
929
930 return REPAIR_INTRO_PAGE;
931}
int toupper(int c)
Definition: utclib.c:881
@ REPAIR_INTRO_PAGE
Definition: usetup.h:86
@ RECOVERY_PAGE
Definition: usetup.h:118

Referenced by RunUSetup().

◆ ResetFileSystemList()

static VOID ResetFileSystemList ( VOID  )
static

Definition at line 2359 of file usetup.c.

2360{
2361 if (!FileSystemList)
2362 return;
2363
2366}
VOID DestroyFileSystemList(IN PFILE_SYSTEM_LIST List)
Definition: fslist.c:149

Referenced by FsVolCallback(), and SelectFileSystemPage().

◆ RunUSetup()

NTSTATUS RunUSetup ( VOID  )

Definition at line 4005 of file usetup.c.

4006{
4008 INPUT_RECORD Ir;
4010 BOOLEAN Old;
4011
4013
4014 /* Tell the Cm this is a setup boot, and it has to behave accordingly */
4016 if (!NT_SUCCESS(Status))
4017 DPRINT1("NtInitializeRegistry() failed (Status 0x%08lx)\n", Status);
4018
4019 /* Initialize the user-mode PnP manager */
4021 if (!NT_SUCCESS(Status))
4022 {
4023 // PrintString(??);
4024 DPRINT1("The user-mode PnP manager could not initialize (Status 0x%08lx), expect unavailable devices!\n", Status);
4025 }
4026
4027 if (!CONSOLE_Init())
4028 {
4032
4033 /* We failed to initialize the video, just quit the installer */
4035 }
4036
4037 /* Hide the cursor and clear the screen and keyboard buffer */
4040 CONSOLE_Flush();
4041
4042 /* Global Initialization page */
4043 Page = SetupStartPage(&Ir);
4044
4045 while (Page != REBOOT_PAGE && Page != RECOVERY_PAGE)
4046 {
4048 CONSOLE_Flush();
4049
4050 // CONSOLE_SetUnderlinedTextXY(4, 3, " ReactOS " KERNEL_VERSION_STR " Setup ");
4051
4052 switch (Page)
4053 {
4054 /* Language page */
4055 case LANGUAGE_PAGE:
4056 Page = LanguagePage(&Ir);
4057 break;
4058
4059 /* Welcome page */
4060 case WELCOME_PAGE:
4061 Page = WelcomePage(&Ir);
4062 break;
4063
4064 /* License page */
4065 case LICENSE_PAGE:
4066 Page = LicensePage(&Ir);
4067 break;
4068
4069 /* Install pages */
4070 case INSTALL_INTRO_PAGE:
4071 Page = InstallIntroPage(&Ir);
4072 break;
4073
4074#if 0
4075 case SCSI_CONTROLLER_PAGE:
4076 Page = ScsiControllerPage(&Ir);
4077 break;
4078
4079 case OEM_DRIVER_PAGE:
4080 Page = OemDriverPage(&Ir);
4081 break;
4082#endif
4083
4085 Page = DeviceSettingsPage(&Ir);
4086 break;
4087
4090 break;
4091
4094 break;
4095
4098 break;
4099
4101 Page = LayoutSettingsPage(&Ir);
4102 break;
4103
4104 /* Partitioning pages */
4107 break;
4108
4111 break;
4112
4115 break;
4116
4119 break;
4120
4121 /* File system partition operations pages */
4124 break;
4125
4126 /* Bootloader selection page */
4129 break;
4130
4131 /* Installation pages */
4134 break;
4135
4136 case PREPARE_COPY_PAGE:
4137 Page = PrepareCopyPage(&Ir);
4138 break;
4139
4140 case FILE_COPY_PAGE:
4141 Page = FileCopyPage(&Ir);
4142 break;
4143
4144 case REGISTRY_PAGE:
4145 Page = RegistryPage(&Ir);
4146 break;
4147
4148 /* Bootloader installation page */
4150 // case BOOTLOADER_REMOVABLE_DISK_PAGE:
4152 break;
4153
4154 /* Repair pages */
4155 case REPAIR_INTRO_PAGE:
4156 Page = RepairIntroPage(&Ir);
4157 break;
4158
4160 Page = UpgradeRepairPage(&Ir);
4161 break;
4162
4163 case SUCCESS_PAGE:
4164 Page = SuccessPage(&Ir);
4165 break;
4166
4167 case FLUSH_PAGE:
4168 Page = FlushPage(&Ir);
4169 break;
4170
4171 case QUIT_PAGE:
4172 Page = QuitPage(&Ir);
4173 break;
4174
4175 /* Virtual pages */
4176 case SETUP_INIT_PAGE:
4179 // case CHECK_FILE_SYSTEM_PAGE:
4180 case REBOOT_PAGE:
4181 case RECOVERY_PAGE:
4182 break;
4183
4184 default:
4185 break;
4186 }
4187 }
4188
4189 /* Terminate the user-mode PnP manager */
4191
4192 /* Setup has finished */
4194
4195 if (Page == RECOVERY_PAGE)
4197
4198 FreeConsole();
4199
4200 /* Reboot */
4204
4205 return STATUS_SUCCESS;
4206}
BOOL WINAPI FreeConsole(VOID)
Definition: console.c:156
NTSTATUS InitializeUserModePnpManager(IN HINF *phSetupInf)
Definition: devinst.c:559
VOID TerminateUserModePnpManager(VOID)
Definition: devinst.c:690
VOID RecoveryConsole(VOID)
Definition: cmdcons.c:1160
BOOLEAN CONSOLE_Init(VOID)
Definition: consup.c:45
VOID InfSetHeap(PVOID Heap)
Definition: infrosgen.c:40
#define SE_SHUTDOWN_PRIVILEGE
Definition: security.c:673
#define CM_BOOT_FLAG_SETUP
Definition: cmtypes.h:159
@ ShutdownReboot
Definition: extypes.h:177
NTSYSAPI NTSTATUS NTAPI RtlAdjustPrivilege(_In_ ULONG Privilege, _In_ BOOLEAN NewValue, _In_ BOOLEAN ForThread, _Out_ PBOOLEAN OldValue)
NTSTATUS NTAPI NtInitializeRegistry(IN USHORT Flag)
Definition: ntapi.c:1318
NTSTATUS NTAPI NtShutdownSystem(IN SHUTDOWN_ACTION Action)
Definition: shutdown.c:43
_In_ PVOID _Out_opt_ BOOLEAN _Out_opt_ PPFN_NUMBER Page
Definition: mm.h:1306
#define STATUS_APP_INIT_FAILURE
Definition: ntstatus.h:561
VOID NTAPI FinishSetup(IN OUT PUSETUP_DATA pSetupData)
Definition: setuplib.c:1103
#define STRING_CONSOLEFAIL1
Definition: mui.h:165
#define STRING_CONSOLEFAIL3
Definition: mui.h:167
#define STRING_CONSOLEFAIL2
Definition: mui.h:166
static PAGE_NUMBER DeviceSettingsPage(PINPUT_RECORD Ir)
Definition: usetup.c:1229
static PAGE_NUMBER FlushPage(PINPUT_RECORD Ir)
Definition: usetup.c:3994
static PAGE_NUMBER DeletePartitionPage(PINPUT_RECORD Ir)
Definition: usetup.c:2193
static PAGE_NUMBER LicensePage(PINPUT_RECORD Ir)
Definition: usetup.c:872
static PAGE_NUMBER DisplaySettingsPage(PINPUT_RECORD Ir)
Definition: usetup.c:1450
static PAGE_NUMBER ComputerSettingsPage(PINPUT_RECORD Ir)
Definition: usetup.c:1424
static PAGE_NUMBER FileCopyPage(PINPUT_RECORD Ir)
Definition: usetup.c:3256
static PAGE_NUMBER KeyboardSettingsPage(PINPUT_RECORD Ir)
Definition: usetup.c:1476
static PAGE_NUMBER LanguagePage(PINPUT_RECORD Ir)
Definition: usetup.c:675
static PAGE_NUMBER StartPartitionOperationsPage(PINPUT_RECORD Ir)
Definition: usetup.c:2274
static PAGE_NUMBER BootLoaderSelectPage(PINPUT_RECORD Ir)
Definition: usetup.c:3410
static PAGE_NUMBER RegistryPage(PINPUT_RECORD Ir)
Definition: usetup.c:3373
static PAGE_NUMBER LayoutSettingsPage(PINPUT_RECORD Ir)
Definition: usetup.c:1502
static PAGE_NUMBER InstallIntroPage(PINPUT_RECORD Ir)
Definition: usetup.c:1096
static PAGE_NUMBER SuccessPage(PINPUT_RECORD Ir)
Definition: usetup.c:3971
static PAGE_NUMBER BootLoaderInstallPage(PINPUT_RECORD Ir)
Definition: usetup.c:3692
static PAGE_NUMBER SelectPartitionPage(PINPUT_RECORD Ir)
Definition: usetup.c:1553
static PAGE_NUMBER WelcomePage(PINPUT_RECORD Ir)
Definition: usetup.c:829
static PAGE_NUMBER ConfirmDeleteSystemPartitionPage(PINPUT_RECORD Ir)
Definition: usetup.c:2153
static PAGE_NUMBER QuitPage(PINPUT_RECORD Ir)
Definition: usetup.c:3932
static VOID PrintString(IN PCSTR fmt,...)
Definition: usetup.c:151
static PAGE_NUMBER CreatePartitionPage(PINPUT_RECORD Ir)
Definition: usetup.c:2044
static PAGE_NUMBER SetupStartPage(PINPUT_RECORD Ir)
Definition: usetup.c:582
static PAGE_NUMBER PrepareCopyPage(PINPUT_RECORD Ir)
Definition: usetup.c:3076
static PAGE_NUMBER RepairIntroPage(PINPUT_RECORD Ir)
Definition: usetup.c:903
static PAGE_NUMBER UpgradeRepairPage(PINPUT_RECORD Ir)
Definition: usetup.c:946
static PAGE_NUMBER InstallDirectoryPage(PINPUT_RECORD Ir)
Definition: usetup.c:2874
@ SELECT_FILE_SYSTEM_PAGE
Definition: usetup.h:102
@ START_PARTITION_OPERATIONS_PAGE
Definition: usetup.h:101
@ SETUP_INIT_PAGE
Definition: usetup.h:77
enum _PAGE_NUMBER PAGE_NUMBER

Referenced by NtProcessStartup().

◆ SelectFileSystemPage()

static FSVOL_OP SelectFileSystemPage ( _In_ PFSVOL_CONTEXT  FsVolContext,
_In_ PVOLENTRY  Volume 
)
static

Definition at line 2369 of file usetup.c.

2372{
2373 PINPUT_RECORD Ir = FsVolContext->Ir;
2374 PPARTENTRY PartEntry = Volume->PartEntry;
2375 PDISKENTRY DiskEntry = PartEntry->DiskEntry;
2376 PCWSTR DefaultFs;
2377 BOOLEAN ForceFormat;
2378 CHAR LineBuffer[100];
2379
2380 DPRINT("SelectFileSystemPage()\n");
2381
2382 ForceFormat = (Volume->New || Volume->FormatState == Unformatted);
2383
2384Restart:
2385 /* Reset the file system list for each volume that is to be formatted */
2387
2389 CONSOLE_Flush();
2391
2392 if (Volume->New & VOLUME_NEW_AUTOCREATE)
2393 {
2394 Volume->New &= ~VOLUME_NEW_AUTOCREATE;
2395
2397 }
2398 else if (Volume->New)
2399 {
2400 ULONG uID;
2401
2402 if (Volume == SystemVolume)
2404 else if (Volume == InstallVolume)
2406 else
2408
2409 CONSOLE_SetTextXY(6, 8, MUIGetString(uID));
2410 }
2411 else
2412 {
2414 }
2415
2416 PartitionDescription(PartEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2417 CONSOLE_SetTextXY(6, 10, LineBuffer);
2418
2419 DiskDescription(DiskEntry, LineBuffer, ARRAYSIZE(LineBuffer));
2421 LineBuffer);
2422
2423 /* Show "This Partition will be formatted next" only if it is unformatted */
2424 if (ForceFormat)
2426
2428
2430 {
2432
2433 switch (USetupData.FsType)
2434 {
2435 /* 1 is for BtrFS */
2436 case 1:
2437 DefaultFs = L"BTRFS";
2438 break;
2439
2440 /* If we don't understand input, default to FAT */
2441 default:
2442 DefaultFs = L"FAT";
2443 break;
2444 }
2445 }
2446 else
2447 {
2448 /* By default select the "FAT" file system */
2449 DefaultFs = L"FAT";
2450 }
2451
2452 /* Create the file system list */
2453 // TODO: Display only the FSes compatible with the selected volume!
2454 FileSystemList = CreateFileSystemList(6, 26, ForceFormat, DefaultFs);
2455 if (!FileSystemList)
2456 {
2457 /* FIXME: show an error dialog */
2458 FsVolContext->NextPageOnAbort = QUIT_PAGE;
2459 return FSVOL_ABORT;
2460 }
2461
2463 {
2465 return FSVOL_DOIT;
2466 }
2467
2469
2470 while (TRUE)
2471 {
2472 CONSOLE_ConInKey(Ir);
2473
2474 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2475 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
2476 {
2477 if (ConfirmQuit(Ir))
2478 {
2479 FsVolContext->NextPageOnAbort = QUIT_PAGE;
2480 return FSVOL_ABORT;
2481 }
2482 break;
2483 }
2484 else if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_ESCAPE) /* ESC */
2485 {
2486 FsVolContext->NextPageOnAbort = SELECT_PARTITION_PAGE;
2487 return FSVOL_ABORT;
2488 }
2489 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2490 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_DOWN)) /* DOWN */
2491 {
2493 }
2494 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
2495 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_UP)) /* UP */
2496 {
2498 }
2499 else if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_RETURN) /* ENTER */
2500 {
2502 {
2503 /* The 'Keep existing filesystem' entry was chosen,
2504 * the volume must be already formatted */
2505 ASSERT(!ForceFormat);
2506
2507 /* Skip formatting this volume. We will also ignore
2508 * file system checks on it, unless it is either the
2509 * system or the installation volume. */
2510 if ((Volume != SystemVolume) && (Volume != InstallVolume))
2511 Volume->NeedsCheck = FALSE;
2512
2513 return FSVOL_SKIP;
2514 }
2515 else
2516 {
2517 /* Format this volume */
2518 return FSVOL_DOIT;
2519 }
2520 }
2521 }
2522
2523 goto Restart;
2524}
VOID ScrollUpFileSystemList(IN PFILE_SYSTEM_LIST List)
Definition: fslist.c:236
VOID DrawFileSystemList(IN PFILE_SYSTEM_LIST List)
Definition: fslist.c:167
VOID ScrollDownFileSystemList(IN PFILE_SYSTEM_LIST List)
Definition: fslist.c:225
PFILE_SYSTEM_LIST CreateFileSystemList(IN SHORT Left, IN SHORT Top, IN BOOLEAN ForceFormat, IN PCWSTR SelectFileSystem)
Definition: fslist.c:109
@ Unformatted
Definition: partlist.h:34
PCWSTR FileSystem
Definition: fslist.h:34
LONG FsType
Definition: setuplib.h:137
#define STRING_NONFORMATTEDSYSTEMPART
Definition: mui.h:146
#define STRING_NONFORMATTEDOTHERPART
Definition: mui.h:147
#define STRING_PARTFORMAT
Definition: mui.h:144
#define STRING_INSTALLONPART
Definition: mui.h:148
#define STRING_NEWPARTITION
Definition: mui.h:143
#define STRING_NONFORMATTEDPART
Definition: mui.h:145
#define VOLUME_NEW_AUTOCREATE
Definition: usetup.c:84

Referenced by FsVolCallback().

◆ SelectPartitionPage()

static PAGE_NUMBER SelectPartitionPage ( PINPUT_RECORD  Ir)
static

Definition at line 1553 of file usetup.c.

1554{
1555 PARTLIST_UI ListUi;
1556 ULONG Error;
1557 ULONGLONG MaxTargetSize;
1558
1559 if (PartitionList == NULL)
1560 {
1562 if (PartitionList == NULL)
1563 {
1565 return QUIT_PAGE;
1566 }
1568 {
1570 return QUIT_PAGE;
1571 }
1572 }
1573
1574 if (RepairUpdateFlag)
1575 {
1577
1578 /* Determine the selected installation disk & partition.
1579 * It must exist and be valid, since this is the partition
1580 * where the existing installation already resides. */
1584 if (!InstallPartition)
1585 {
1586 DPRINT1("RepairUpdateFlag == TRUE, SelectPartition() returned FALSE, assert!\n");
1587 ASSERT(FALSE);
1588 }
1591
1593 }
1594
1596
1599 2, 21,
1600 xScreen - 3,
1601 yScreen - 3);
1602 DrawPartitionList(&ListUi);
1603
1604 if (IsUnattendedSetup) do
1605 {
1606 /* If DestinationDiskNumber or DestinationPartitionNumber are invalid
1607 * (see below), don't select the partition and show the list instead */
1610 {
1611 break;
1612 }
1613
1614 /* Determine the selected installation disk & partition */
1618
1619 /* Now reset DestinationDiskNumber and DestinationPartitionNumber
1620 * to *invalid* values, so that if the corresponding partition is
1621 * determined to be invalid by the code below or in CreateInstallPartition,
1622 * we don't reselect it when SelectPartitionPage() is called again */
1625
1626 // FIXME: Here and in the AutoPartition case below, the CurrentPartition
1627 // may actually be unsuitable (MBR-extended, non-simple volume...).
1628 // More checks need to be made here!
1629 //
1630 // NOTE: We don't check for CurrentPartition->Volume in case
1631 // the partition doesn't contain a recognized volume/none exists.
1632 // We also don't check whether IsPartitioned is TRUE, because if
1633 // the partition is still empty space, we'll try to partition it.
1635 goto CreateInstallPartition;
1636
1638 {
1640 // TODO: Do more checks, and loop until we find a valid partition.
1641 goto CreateInstallPartition;
1642 }
1643 } while (0);
1644
1645 while (TRUE)
1646 {
1647 ULONG uID;
1648
1650
1651 /* Update status text */
1652 if (!CurrentPartition)
1653 {
1654 // FIXME: If we get a NULL current partition, this means that
1655 // the current disk is of unrecognized type. So we should display
1656 // instead a status string to initialize the disk with one of
1657 // the recognized partitioning schemes (MBR, later: GPT, etc.)
1658 // For the time being we don't have that, so use instead another
1659 // known string.
1661 }
1662 else
1663 {
1665 {
1669 {
1671 }
1672 }
1673 else
1674 {
1678 }
1679 }
1681
1682 CONSOLE_ConInKey(Ir);
1683
1684 if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1685 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
1686 {
1687 if (ConfirmQuit(Ir))
1688 {
1691 return QUIT_PAGE;
1692 }
1693 return SELECT_PARTITION_PAGE;
1694 }
1695 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1696 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_DOWN)) /* DOWN */
1697 {
1699 }
1700 else if ((Ir->Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1701 (Ir->Event.KeyEvent.wVirtualKeyCode == VK_UP)) /* UP */
1702 {
1704 }
1705 else if (Ir->Event.KeyEvent.wVirtualKeyCode == VK_RETURN) /* ENTER */
1706 {
1708
1709 /* Don't select an extended partition for OS installation */
1711 continue;
1712
1713 /*
1714 * Check whether the user wants to install ReactOS on a disk that
1715 * is not recognized by the computer's firmware and if so, display
1716 * a warning since such disks may not be bootable.
1717 */
1718 if (CurrentPartition->DiskEntry->MediaType == FixedMedia &&
1719 !CurrentPartition->DiskEntry->BiosFound)
1720 {
1721 PopupError("The disk you have selected for installing ReactOS\n"
1722 "is not visible by the firmware of your computer,\n"
1723 "and so may not be bootable.\n"
1724 "Press ENTER to continue anyway.",
1726 Ir, POPUP_WAIT_ENTER);
1727 // return SELECT_PARTITION_PAGE;
1728 }
1729
1730 goto CreateInstallPartition;
1731 }
1732 else if (Ir->Event.KeyEvent.wVirtualKeyCode == 'C') /* C */
1733 {
1735
1737 if (Error != NOT_AN_ERROR)
1738 {
1740 return SELECT_PARTITION_PAGE;
1741 }
1742
1744 return CREATE_PARTITION_PAGE;
1745 }
1746 else if (Ir->Event.KeyEvent.wVirtualKeyCode == 'E') /* E */
1747 {
1749
1750 /* Don't create an extended partition within a logical partition */
1752 continue;
1753
1755 if (Error != NOT_AN_ERROR)
1756 {
1758 return SELECT_PARTITION_PAGE;
1759 }
1760
1762 return CREATE_PARTITION_PAGE;
1763 }
1764 else if (Ir->Event.KeyEvent.wVirtualKeyCode == 'D') /* D */
1765 {
1767
1768 /* Ignore deletion in case this is not a partitioned entry */
1770 continue;
1771
1772// TODO: Do something similar before trying to format the partition?
1775 {
1776 UNICODE_STRING CurrentPartitionU;
1777 WCHAR PathBuffer[RTL_NUMBER_OF_FIELD(VOLINFO, DeviceName) + 1];
1778
1780
1781 RtlStringCchPrintfW(PathBuffer, _countof(PathBuffer),
1783 RtlInitUnicodeString(&CurrentPartitionU, PathBuffer);
1784
1785 /*
1786 * Check whether the user attempts to delete the partition on which
1787 * the installation source is present. If so, fail with an error.
1788 */
1789 // &USetupData.SourceRootPath
1790 if (RtlPrefixUnicodeString(&CurrentPartitionU, &USetupData.SourcePath, TRUE))
1791 {
1793 return SELECT_PARTITION_PAGE;
1794 }
1795 }
1796
1799 {
1801 }
1802
1803 return DELETE_PARTITION_PAGE;
1804 }
1805 }
1806
1807CreateInstallPartition:
1810
1811 /* Create the partition if the selected region is empty */
1813 {
1815 if (Error != NOT_AN_ERROR)
1816 {
1818 return SELECT_PARTITION_PAGE;
1819 }
1820
1821 /* Automatically create the partition on the whole empty space;
1822 * it will be formatted later with default parameters */
1825 0ULL,
1826 0);
1830 }
1831
1832 /* Verify the target medium size */
1834 if (!IsMediumLargeEnough(MaxTargetSize))
1835 {
1838 return SELECT_PARTITION_PAGE; /* Let the user select another partition */
1839 }
1840
1843}
static VOID DrawPartitionList(_In_ HWND hWndList, _In_ PPARTLIST List)
Definition: drivepage.c:1381
#define IsListEmpty(ListHead)
Definition: env_spec_w32.h:954
@ NOT_AN_ERROR
Definition: errorcode.h:17
@ ERROR_DRIVE_INFORMATION
Definition: errorcode.h:27
@ ERROR_INSUFFICIENT_PARTITION_SIZE
Definition: errorcode.h:57
@ ERROR_SOURCE_PATH
Definition: errorcode.h:20
@ ERROR_NO_HDD
Definition: errorcode.h:22
#define ULL(a, b)
Definition: format_msg.c:27
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
#define IsContainerPartition(PartitionType)
Definition: ntdddisk.h:321
@ FixedMedia
Definition: ntdddisk.h:383
ERROR_NUMBER NTAPI PartitionCreateChecks(_In_ PPARTENTRY PartEntry, _In_opt_ ULONGLONG SizeBytes, _In_opt_ ULONG_PTR PartitionInfo)
Definition: partlist.c:2881
BOOLEAN IsPartitionActive(IN PPARTENTRY PartEntry)
Definition: partlist.c:1907
PPARTLIST NTAPI CreatePartitionList(VOID)
Definition: partlist.c:1988
PPARTENTRY SelectPartition(_In_ PPARTLIST List, _In_ ULONG DiskNumber, _In_ ULONG PartitionNumber)
Definition: partlist.c:2268
VOID ScrollUpDownPartitionList(_In_ PPARTLIST_UI ListUi, _In_ BOOLEAN Direction)
Definition: partlist.c:841
VOID InitPartitionListUi(IN OUT PPARTLIST_UI ListUi, IN PPARTLIST List, IN PPARTENTRY CurrentEntry OPTIONAL, IN SHORT Left, IN SHORT Top, IN SHORT Right, IN SHORT Bottom)
Definition: partlist.c:351
ULONG PartitionNumber
Definition: osdetect.h:24
PVOLENTRY Volume
Definition: partlist.h:95
PPARTENTRY CurrentPartition
Definition: partlist.h:43
LIST_ENTRY DiskListHead
Definition: partlist.h:183
LONG DestinationPartitionNumber
Definition: setuplib.h:132
LONG AutoPartition
Definition: setuplib.h:136
LONG DestinationDiskNumber
Definition: setuplib.h:131
FORMATSTATE FormatState
Definition: partlist.h:48
BOOLEAN New
Definition: partlist.h:53
#define STRING_DELETEPARTITION
Definition: mui.h:136
#define STRING_INSTALLCREATELOGICAL
Definition: mui.h:134
#define STRING_INSTALLDELETEPARTITION
Definition: mui.h:135
#define STRING_INSTALLCREATEPARTITION
Definition: mui.h:133
static BOOLEAN IsMediumLargeEnough(_In_ ULONGLONG SizeInBytes)
Definition: usetup.c:1518

Referenced by RunUSetup().

◆ SetupStartPage()

static PAGE_NUMBER SetupStartPage ( PINPUT_RECORD  Ir)
static

Definition at line 582 of file usetup.c.

583{
584 ULONG Error;
585 PGENERIC_LIST_ENTRY ListEntry;
587
589
590 /* Initialize Setup */
593 if (Error != ERROR_SUCCESS)
594 {
596 return QUIT_PAGE;
597 }
598
599 /* Initialize the user-mode PnP manager */
601 DPRINT1("The user-mode PnP manager could not initialize, expect unavailable devices!\n");
602
603 /* Wait for any immediate pending installations to finish */
605 DPRINT1("WaitNoPendingInstallEvents() failed to wait!\n");
606
608
610 {
611 // TODO: Read options from inf
612 /* Load the hardware, language and keyboard layout lists */
613
617
619
620 /* new part */
624
626
627 /* first we hack LanguageList */
628 for (ListEntry = GetFirstListEntry(USetupData.LanguageList); ListEntry;
629 ListEntry = GetNextListEntry(ListEntry))
630 {
631 LocaleId = ((PGENENTRY)GetListEntryData(ListEntry))->Id;
633 {
634 DPRINT("found %S in LanguageList\n", LocaleId);
636 break;
637 }
638 }
639
640 /* now LayoutList */
641 for (ListEntry = GetFirstListEntry(USetupData.LayoutList); ListEntry;
642 ListEntry = GetNextListEntry(ListEntry))
643 {
644 LocaleId = ((PGENENTRY)GetListEntryData(ListEntry))->Id;
646 {
647 DPRINT("found %S in LayoutList\n", LocaleId);
649 break;
650 }
651 }
652
654
655 return INSTALL_INTRO_PAGE;
656 }
657
658 return LANGUAGE_PAGE;
659}
DWORD Id
NTSTATUS WaitNoPendingInstallEvents(IN PLARGE_INTEGER Timeout OPTIONAL)
Definition: devinst.c:514
BOOLEAN EnableUserModePnpManager(VOID)
Definition: devinst.c:521
SPFILE_EXPORTS SpFileExports
Definition: fileqsup.c:23
SPINF_EXPORTS SpInfExports
Definition: infsupp.c:24
VOID NTAPI SetCurrentListEntry(IN PGENERIC_LIST List, IN PGENERIC_LIST_ENTRY Entry)
Definition: genlist.c:91
PGENERIC_LIST_ENTRY NTAPI GetFirstListEntry(IN PGENERIC_LIST List)
Definition: genlist.c:110
PGENERIC_LIST_ENTRY NTAPI GetNextListEntry(IN PGENERIC_LIST_ENTRY Entry)
Definition: genlist.c:121
ERROR_NUMBER NTAPI InitializeSetup(_Inout_ PUSETUP_DATA pSetupData, _In_opt_ PSETUP_ERROR_ROUTINE ErrorRoutine, _In_ PSPFILE_EXPORTS pSpFileExports, _In_ PSPINF_EXPORTS pSpInfExports)
Definition: setuplib.c:1019
VOID NTAPI CheckUnattendedSetup(IN OUT PUSETUP_DATA pSetupData)
Definition: setuplib.c:32
Definition: genlist.h:11
WCHAR LocaleID[9]
Definition: setuplib.h:155
static VOID __cdecl USetupErrorRoutine(IN PUSETUP_DATA pSetupData,...)
Definition: usetup.c:539
_Must_inspect_result_ _In_ PWDFDEVICE_INIT _In_ PCUNICODE_STRING _In_ PCUNICODE_STRING _In_ LCID LocaleId
Definition: wdfpdo.h:437

Referenced by RunUSetup().

◆ SetupUpdateMemoryInfo()

static VOID SetupUpdateMemoryInfo ( IN PCOPYCONTEXT  CopyContext,
IN BOOLEAN  First 
)
static

Definition at line 3102 of file usetup.c.

3104{
3106
3107 /* Get the memory information from the system */
3109 &PerfInfo,
3110 sizeof(PerfInfo),
3111 NULL);
3112
3113 /* Check if this is initial setup */
3114 if (First)
3115 {
3116 /* Set maximum limits to be total RAM pages */
3117 ProgressSetStepCount(CopyContext->MemoryBars[0], PerfInfo.CommitLimit);
3118 ProgressSetStepCount(CopyContext->MemoryBars[1], PerfInfo.CommitLimit);
3119 ProgressSetStepCount(CopyContext->MemoryBars[2], PerfInfo.CommitLimit);
3120 }
3121
3122 /* Set current values */
3123 ProgressSetStep(CopyContext->MemoryBars[0], PerfInfo.PagedPoolPages + PerfInfo.NonPagedPoolPages);
3124 ProgressSetStep(CopyContext->MemoryBars[1], PerfInfo.ResidentSystemCachePage);
3125 ProgressSetStep(CopyContext->MemoryBars[2], PerfInfo.AvailablePages);
3126}
WCHAR First[]
Definition: FormatMessage.c:11
#define SystemPerformanceInformation
Definition: memtest.h:87
NTSYSAPI NTSTATUS NTAPI NtQuerySystemInformation(IN SYSTEM_INFORMATION_CLASS SystemInfoClass, OUT PVOID SystemInfoBuffer, IN ULONG SystemInfoBufferSize, OUT PULONG BytesReturned OPTIONAL)

Referenced by FileCopyCallback().

◆ ShowPartitionSizeInputBox()

static VOID ShowPartitionSizeInputBox ( SHORT  Left,
SHORT  Top,
SHORT  Right,
SHORT  Bottom,
ULONG  MaxSize,
PWSTR  InputBuffer,
PBOOLEAN  Quit,
PBOOLEAN  Cancel 
)
static

Definition at line 1851 of file usetup.c.

1859{
1860 INPUT_RECORD Ir;
1861 COORD coPos;
1862 DWORD Written;
1863 CHAR Buffer[128];
1864 INT Length, Pos;
1865 WCHAR ch;
1866 SHORT iLeft;
1867 SHORT iTop;
1868
1869 if (Quit != NULL)
1870 *Quit = FALSE;
1871
1872 if (Cancel != NULL)
1873 *Cancel = FALSE;
1874
1875 DrawBox(Left, Top, Right - Left + 1, Bottom - Top + 1);
1876
1877 /* Print message */
1878 coPos.X = Left + 2;
1879 coPos.Y = Top + 2;
1881 iLeft = coPos.X + (USHORT)strlen(Buffer) + 1;
1882 iTop = coPos.Y;
1883
1885 Buffer,
1886 strlen(Buffer),
1887 coPos,
1888 &Written);
1889
1891 coPos.X = iLeft + PARTITION_SIZE_INPUT_FIELD_LENGTH + 1;
1892 coPos.Y = iTop;
1894 Buffer,
1895 strlen(Buffer),
1896 coPos,
1897 &Written);
1898
1899 swprintf(InputBuffer, L"%lu", MaxSize);
1901 Pos = Length;
1903 iTop,
1905 InputBuffer);
1906 CONSOLE_SetCursorXY(iLeft + Length, iTop);
1908
1909 while (TRUE)
1910 {
1911 CONSOLE_ConInKey(&Ir);
1912
1913 if ((Ir.Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1914 (Ir.Event.KeyEvent.wVirtualKeyCode == VK_F3)) /* F3 */
1915 {
1916 if (Quit != NULL)
1917 *Quit = TRUE;
1918
1920 break;
1921 }
1922 else if (Ir.Event.KeyEvent.wVirtualKeyCode == VK_RETURN) /* ENTER */
1923 {
1924 break;
1925 }
1926 else if (Ir.Event.KeyEvent.wVirtualKeyCode == VK_ESCAPE) /* ESC */
1927 {
1928 if (Cancel != NULL)
1929 *Cancel = TRUE;
1930
1932 break;
1933 }
1934 else if ((Ir.Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1935 (Ir.Event.KeyEvent.wVirtualKeyCode == VK_HOME)) /* HOME */
1936 {
1937 Pos = 0;
1938 CONSOLE_SetCursorXY(iLeft + Pos, iTop);
1939 }
1940 else if ((Ir.Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1941 (Ir.Event.KeyEvent.wVirtualKeyCode == VK_END)) /* END */
1942 {
1943 Pos = Length;
1944 CONSOLE_SetCursorXY(iLeft + Pos, iTop);
1945 }
1946 else if ((Ir.Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1947 (Ir.Event.KeyEvent.wVirtualKeyCode == VK_LEFT)) /* LEFT */
1948 {
1949 if (Pos > 0)
1950 {
1951 Pos--;
1952 CONSOLE_SetCursorXY(iLeft + Pos, iTop);
1953 }
1954 }
1955 else if ((Ir.Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1956 (Ir.Event.KeyEvent.wVirtualKeyCode == VK_RIGHT)) /* RIGHT */
1957 {
1958 if (Pos < Length)
1959 {
1960 Pos++;
1961 CONSOLE_SetCursorXY(iLeft + Pos, iTop);
1962 }
1963 }
1964 else if ((Ir.Event.KeyEvent.uChar.AsciiChar == 0x00) &&
1965 (Ir.Event.KeyEvent.wVirtualKeyCode == VK_DELETE)) /* DEL */
1966 {
1967 if (Pos < Length)
1968 {
1970 &InputBuffer[Pos + 1],
1971 (Length - Pos - 1) * sizeof(WCHAR));
1973
1974 Length--;
1976 iTop,
1978 InputBuffer);
1979 CONSOLE_SetCursorXY(iLeft + Pos, iTop);
1980 }
1981 }
1982 else if (Ir.Event.KeyEvent.wVirtualKeyCode == VK_BACK) /* BACKSPACE */
1983 {
1984 if (Pos > 0)
1985 {
1986 if (Pos < Length)
1987 memmove(&InputBuffer[Pos - 1],
1988 &InputBuffer[Pos],
1989 (Length - Pos) * sizeof(WCHAR));
1991
1992 Pos--;
1993 Length--;
1995 iTop,
1997 InputBuffer);
1998 CONSOLE_SetCursorXY(iLeft + Pos, iTop);
1999 }
2000 }
2001 else if (Ir.Event.KeyEvent.uChar.AsciiChar != 0x00)
2002 {
2004 {
2006
2007 if ((ch >= L'0') && (ch <= L'9'))
2008 {
2009 if (Pos < Length)
2010 memmove(&InputBuffer[Pos + 1],
2011 &InputBuffer[Pos],
2012 (Length - Pos) * sizeof(WCHAR));
2014 InputBuffer[Pos] = ch;
2015
2016 Pos++;
2017 Length++;
2019 iTop,
2021 InputBuffer);
2022 CONSOLE_SetCursorXY(iLeft + Pos, iTop);
2023 }
2024 }
2025 }
2026 }
2027
2029}
char * strcpy(char *DstString, const char *SrcString)
Definition: utclib.c:388
static LPHIST_ENTRY Bottom
Definition: history.c:54
static LPHIST_ENTRY Top
Definition: history.c:53
#define swprintf
Definition: precomp.h:40
#define sprintf(buf, format,...)
Definition: sprintf.c:55
int32_t INT
Definition: typedefs.h:58
#define STRING_MAXSIZE
Definition: mui.h:179
#define STRING_PARTITIONSIZE
Definition: mui.h:137
#define PARTITION_SIZE_INPUT_FIELD_LENGTH
Definition: usetup.c:1846
#define VK_BACK
Definition: winuser.h:2201

Referenced by CreatePartitionPage().

◆ StartPartitionOperationsPage()

static PAGE_NUMBER StartPartitionOperationsPage ( PINPUT_RECORD  Ir)
static

Definition at line 2274 of file usetup.c.

2275{
2276 FSVOL_CONTEXT FsVolContext = {Ir, QUIT_PAGE};
2278
2280 {
2281 /* FIXME: show an error dialog */
2282 return QUIT_PAGE;
2283 }
2284
2285 /* Find or set the active system partition before starting formatting */
2290 &FsVolContext);
2291 if (!Success)
2292 return FsVolContext.NextPageOnAbort;
2293 //
2294 // FIXME?? If cannot use any system partition, install FreeLdr on floppy / removable media??
2295 //
2296
2297 /* Set the AUTOCREATE flag if the system partition was automatically created */
2300
2302 CONSOLE_Flush();
2303
2304 /* Apply all pending operations on partitions: formatting and checking */
2309 &FsVolContext);
2310 if (!Success)
2311 return FsVolContext.NextPageOnAbort;
2313}
BOOLEAN NTAPI FsVolCommitOpsQueue(_In_ PPARTLIST PartitionList, _In_ PVOLENTRY SystemVolume, _In_ PVOLENTRY InstallVolume, _In_opt_ PFSVOL_CALLBACK FsVolCallback, _In_opt_ PVOID Context)
Definition: fsutil.c:1097
BOOLEAN NTAPI InitSystemPartition(_In_ PPARTLIST PartitionList, _In_ PPARTENTRY InstallPartition, _Out_ PPARTENTRY *pSystemPartition, _In_opt_ PFSVOL_CALLBACK FsVolCallback, _In_opt_ PVOID Context)
Find or set the active system partition.
Definition: setuplib.c:678
BOOLEAN New
Definition: partlist.h:85
static FSVOL_OP CALLBACK FsVolCallback(_In_opt_ PVOID Context, _In_ FSVOLNOTIFY FormatStatus, _In_ ULONG_PTR Param1, _In_ ULONG_PTR Param2)
Definition: usetup.c:2600

Referenced by RunUSetup().

◆ SuccessPage()

static PAGE_NUMBER SuccessPage ( PINPUT_RECORD  Ir)
static

Definition at line 3971 of file usetup.c.

3972{
3974
3976 return FLUSH_PAGE;
3977
3978 /* Wait for maximum 15 seconds or an ENTER key before quitting */
3979 ProgressCountdown(Ir, 15);
3980 return FLUSH_PAGE;
3981}

Referenced by RunUSetup().

◆ UpdateKBLayout()

static VOID UpdateKBLayout ( VOID  )
static

Definition at line 460 of file usetup.c.

461{
462 PGENERIC_LIST_ENTRY ListEntry;
463 KLID newLayout;
464
466
468 {
471 {
472 /* FIXME: Handle error! */
473 return;
474 }
475 }
476
477 /* Search for default layout (if provided) */
478 if (newLayout != 0)
479 {
480 for (ListEntry = GetFirstListEntry(USetupData.LayoutList); ListEntry;
481 ListEntry = GetNextListEntry(ListEntry))
482 {
483 PCWSTR pszLayoutId = ((PGENENTRY)GetListEntryData(ListEntry))->Id;
484 KLID LayoutId = (KLID)(pszLayoutId ? wcstoul(pszLayoutId, NULL, 16) : 0);
485 if (newLayout == LayoutId)
486 {
488 break;
489 }
490 }
491 }
492}
_Check_return_ unsigned long __cdecl wcstoul(_In_z_ const wchar_t *_Str, _Out_opt_ _Deref_post_z_ wchar_t **_EndPtr, _In_ int _Radix)
KLID MUIDefaultKeyboardLayout(IN PCWSTR LanguageId)
Definition: mui.c:88
ULONG KLID
Definition: mui.h:10

Referenced by LanguagePage().

◆ UpgradeRepairPage()

static PAGE_NUMBER UpgradeRepairPage ( PINPUT_RECORD