/* * ReactOS kernel * Copyright (C) 2003 ReactOS Team * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ /* * COPYRIGHT: See COPYING in the top level directory * PROJECT: ReactOS text-mode setup * FILE: base/setup/usetup/fslist.c * PURPOSE: Filesystem list functions * PROGRAMMER: Casper S. Hornstrup (chorns@users.sourceforge.net) */ #include "usetup.h" #define NDEBUG #include /* Enable this define to hide FAT32 choice in case FAT is already present */ #define HIDE_FAT32_CHOICE /* FUNCTIONS ****************************************************************/ static VOID AddProvider( IN OUT PFILE_SYSTEM_LIST List, IN PCWSTR FileSystem) { PFILE_SYSTEM_ITEM Item; Item = (PFILE_SYSTEM_ITEM)RtlAllocateHeap(ProcessHeap, 0, sizeof(*Item)); if (!Item) return; Item->FileSystem = FileSystem; Item->QuickFormat = TRUE; InsertTailList(&List->ListHead, &Item->ListEntry); if (!FileSystem) return; Item = (PFILE_SYSTEM_ITEM)RtlAllocateHeap(ProcessHeap, 0, sizeof(*Item)); if (!Item) return; Item->FileSystem = FileSystem; Item->QuickFormat = FALSE; InsertTailList(&List->ListHead, &Item->ListEntry); } static VOID InitializeFileSystemList( IN OUT PFILE_SYSTEM_LIST List, IN BOOLEAN ForceFormat) { PCWSTR FileSystemName; ULONG Index; #ifdef HIDE_FAT32_CHOICE BOOLEAN FatPresent = FALSE; /* Check whether the FAT filesystem is present */ Index = 0; while (GetRegisteredFileSystems(Index++, &FileSystemName)) { if (wcsicmp(FileSystemName, L"FAT") == 0) { FatPresent = TRUE; break; } } #endif Index = 0; while (GetRegisteredFileSystems(Index++, &FileSystemName)) { #ifdef HIDE_FAT32_CHOICE /* USETUP only: If the FAT filesystem is present, show it, but * don't display FAT32. The FAT formatter will automatically * determine whether to use FAT12/16 or FAT32. */ if (FatPresent && wcsicmp(FileSystemName, L"FAT32") == 0) continue; #endif AddProvider(List, FileSystemName); } if (!ForceFormat) { /* Add the 'Keep existing filesystem' dummy provider */ AddProvider(List, NULL); } } PFILE_SYSTEM_LIST CreateFileSystemList( IN SHORT Left, IN SHORT Top, IN BOOLEAN ForceFormat, IN PCWSTR SelectFileSystem) { PFILE_SYSTEM_LIST List; PFILE_SYSTEM_ITEM Item; PLIST_ENTRY ListEntry; List = (PFILE_SYSTEM_LIST)RtlAllocateHeap(ProcessHeap, 0, sizeof(*List)); if (List == NULL) return NULL; List->Left = Left; List->Top = Top; List->Selected = NULL; InitializeListHead(&List->ListHead); InitializeFileSystemList(List, ForceFormat); /* Search for SelectFileSystem in list */ ListEntry = List->ListHead.Flink; while (ListEntry != &List->ListHead) { Item = CONTAINING_RECORD(ListEntry, FILE_SYSTEM_ITEM, ListEntry); if (Item->FileSystem && wcsicmp(SelectFileSystem, Item->FileSystem) == 0) { List->Selected = Item; break; } ListEntry = ListEntry->Flink; } if (!List->Selected) List->Selected = CONTAINING_RECORD(List->ListHead.Flink, FILE_SYSTEM_ITEM, ListEntry); return List; } VOID DestroyFileSystemList( IN PFILE_SYSTEM_LIST List) { PLIST_ENTRY ListEntry; PFILE_SYSTEM_ITEM Item; ListEntry = List->ListHead.Flink; while (!IsListEmpty(&List->ListHead)) { ListEntry = RemoveHeadList(&List->ListHead); Item = CONTAINING_RECORD(ListEntry, FILE_SYSTEM_ITEM, ListEntry); RtlFreeHeap(ProcessHeap, 0, Item); } RtlFreeHeap(ProcessHeap, 0, List); } VOID DrawFileSystemList( IN PFILE_SYSTEM_LIST List) { PLIST_ENTRY ListEntry; PFILE_SYSTEM_ITEM Item; COORD coPos; DWORD Written; ULONG Index = 0; CHAR Buffer[128]; ListEntry = List->ListHead.Flink; while (ListEntry != &List->ListHead) { Item = CONTAINING_RECORD(ListEntry, FILE_SYSTEM_ITEM, ListEntry); coPos.X = List->Left; coPos.Y = List->Top + (SHORT)Index; FillConsoleOutputAttribute(StdOutput, FOREGROUND_WHITE | BACKGROUND_BLUE, sizeof(Buffer), coPos, &Written); FillConsoleOutputCharacterA(StdOutput, ' ', sizeof(Buffer), coPos, &Written); if (Item->FileSystem) { snprintf(Buffer, sizeof(Buffer), MUIGetString(Item->QuickFormat ? STRING_FORMATDISK1 : STRING_FORMATDISK2), Item->FileSystem); } else { snprintf(Buffer, sizeof(Buffer), MUIGetString(STRING_KEEPFORMAT)); } if (ListEntry == &List->Selected->ListEntry) { CONSOLE_SetInvertedTextXY(List->Left, List->Top + (SHORT)Index, Buffer); } else { CONSOLE_SetTextXY(List->Left, List->Top + (SHORT)Index, Buffer); } Index++; ListEntry = ListEntry->Flink; } } VOID ScrollDownFileSystemList( IN PFILE_SYSTEM_LIST List) { if (List->Selected->ListEntry.Flink != &List->ListHead) { List->Selected = CONTAINING_RECORD(List->Selected->ListEntry.Flink, FILE_SYSTEM_ITEM, ListEntry); DrawFileSystemList(List); } } VOID ScrollUpFileSystemList( IN PFILE_SYSTEM_LIST List) { if (List->Selected->ListEntry.Blink != &List->ListHead) { List->Selected = CONTAINING_RECORD(List->Selected->ListEntry.Blink, FILE_SYSTEM_ITEM, ListEntry); DrawFileSystemList(List); } } /* EOF */