Added NLS-file loader.

svn path=/trunk/; revision=2441
This commit is contained in:
Eric Kohl 2001-12-28 21:21:27 +00:00
parent d6278aba2a
commit 5a38010118

View file

@ -100,8 +100,6 @@ LoadDriver(PCHAR szFileName, int nPos)
strcat(value, szFileName); strcat(value, szFileName);
else else
strcat(value, p + 1); strcat(value, p + 1);
while (strlen(value) < 80)
strcat(value, " ");
DrawStatusText(value); DrawStatusText(value);
/* /*
@ -115,6 +113,42 @@ LoadDriver(PCHAR szFileName, int nPos)
} }
static BOOL
LoadNlsFile(PCHAR szFileName, PCHAR szModuleName)
{
PFILE FilePointer;
char value[256];
char *p;
FilePointer = OpenFile(szFileName);
if (FilePointer == NULL)
{
strcat(value, szFileName);
strcat(value, " not found.");
MessageBox(value);
return(FALSE);
}
/*
* Update the status bar with the current file
*/
strcpy(value, " Reading ");
p = strrchr(szFileName, '\\');
if (p == NULL)
strcat(value, szFileName);
else
strcat(value, p + 1);
DrawStatusText(value);
/*
* Load the driver
*/
MultiBootLoadModule(FilePointer, szModuleName, NULL);
return(TRUE);
}
static VOID static VOID
LoadBootDrivers(PCHAR szSystemRoot, int nPos) LoadBootDrivers(PCHAR szSystemRoot, int nPos)
{ {
@ -231,18 +265,105 @@ LoadBootDrivers(PCHAR szSystemRoot, int nPos)
} }
// printf(" Loading driver: '%s'\n", ImagePath); // printf(" Loading driver: '%s'\n", ImagePath);
LoadDriver(ImagePath, nPos);
if (nPos < 100) if (nPos < 100)
nPos += 5; nPos += 5;
LoadDriver(ImagePath, nPos);
} }
Index++; Index++;
} }
} }
while(done == FALSE); while(done == FALSE);
} }
static BOOL
LoadNlsFiles(PCHAR szSystemRoot)
{
LONG rc = ERROR_SUCCESS;
HKEY hKey;
char szIdBuffer[80];
char szNameBuffer[80];
char szFileName[256];
ULONG BufferSize;
/* open the codepage key */
rc = RegOpenKey(NULL,
"\\Registry\\Machine\\SYSTEM\\CurrentControlSet\\Control\\NLS\\CodePage",
&hKey);
if (rc != ERROR_SUCCESS)
return(FALSE);
/* get ANSI codepage */
BufferSize = 80;
rc = RegQueryValue(hKey, "ACP", NULL, (PUCHAR)szIdBuffer, &BufferSize);
if (rc != ERROR_SUCCESS)
return(FALSE);
BufferSize = 80;
rc = RegQueryValue(hKey, szIdBuffer, NULL, (PUCHAR)szNameBuffer, &BufferSize);
if (rc != ERROR_SUCCESS)
return(FALSE);
/* load ANSI codepage table */
strcpy(szFileName, szSystemRoot);
strcat(szFileName, "system32\\");
strcat(szFileName, szNameBuffer);
if (!LoadNlsFile(szFileName, "ANSI.NLS"))
return(FALSE);
/* get OEM codepage */
BufferSize = 80;
rc = RegQueryValue(hKey, "OEMCP", NULL, (PUCHAR)szIdBuffer, &BufferSize);
if (rc != ERROR_SUCCESS)
return(FALSE);
BufferSize = 80;
rc = RegQueryValue(hKey, szIdBuffer, NULL, (PUCHAR)szNameBuffer, &BufferSize);
if (rc != ERROR_SUCCESS)
return(FALSE);
/* load OEM codepage table */
strcpy(szFileName, szSystemRoot);
strcat(szFileName, "system32\\");
strcat(szFileName, szNameBuffer);
if (!LoadNlsFile(szFileName, "OEM.NLS"))
return(FALSE);
/* open the language key */
rc = RegOpenKey(NULL,
"\\Registry\\Machine\\SYSTEM\\CurrentControlSet\\Control\\NLS\\Language",
&hKey);
if (rc != ERROR_SUCCESS)
return(FALSE);
/* get the Unicode case table */
BufferSize = 80;
rc = RegQueryValue(hKey, "Default", NULL, (PUCHAR)szIdBuffer, &BufferSize);
if (rc != ERROR_SUCCESS)
return(FALSE);
BufferSize = 80;
rc = RegQueryValue(hKey, szIdBuffer, NULL, (PUCHAR)szNameBuffer, &BufferSize);
if (rc != ERROR_SUCCESS)
return(FALSE);
/* load Unicode case table */
strcpy(szFileName, szSystemRoot);
strcat(szFileName, "system32\\");
strcat(szFileName, szNameBuffer);
if (!LoadNlsFile(szFileName, "UNICASE.NLS"))
return(FALSE);
return(TRUE);
}
void LoadAndBootReactOS(PUCHAR OperatingSystemName) void LoadAndBootReactOS(PUCHAR OperatingSystemName)
{ {
PFILE FilePointer; PFILE FilePointer;
@ -487,7 +608,7 @@ void LoadAndBootReactOS(PUCHAR OperatingSystemName)
*/ */
DetectHardware(); DetectHardware();
// Base = MultiBootCreateModule(HARDWARE.HIV); // Base = MultiBootCreateModule(HARDWARE.HIV);
// RegExportHardwareHive(Base, &Size); // RegExportHive("\\Registry\\Machine\\HARDWARE", Base, &Size);
// MultiBootCloseModule(Base, Size); // MultiBootCloseModule(Base, Size);
DrawProgressBar(20); DrawProgressBar(20);
@ -495,14 +616,18 @@ void LoadAndBootReactOS(PUCHAR OperatingSystemName)
/* /*
* load NLS files * load NLS files
*/ */
// LoadNlsFiles(szBootPath); if (!LoadNlsFiles(szBootPath))
{
MessageBox("Failed to load NLS files\n");
return;
}
DrawProgressBar(25); DrawProgressBar(25);
/* /*
* load boot drivers * load boot drivers
*/ */
LoadBootDrivers(szBootPath, 30); LoadBootDrivers(szBootPath, 25);
/* /*