mirror of
https://github.com/reactos/reactos.git
synced 2024-07-18 10:26:09 +00:00
a few fixes to the shell
svn path=/trunk/; revision=1160
This commit is contained in:
parent
dd76e08c86
commit
1410c2b0a4
|
@ -1,4 +1,4 @@
|
||||||
/* $Id: shell.c,v 1.38 2000/05/01 14:15:01 ea Exp $
|
/* $Id: shell.c,v 1.39 2000/05/26 05:38:42 phreak Exp $
|
||||||
*
|
*
|
||||||
* PROJECT : ReactOS Operating System
|
* PROJECT : ReactOS Operating System
|
||||||
* DESCRIPTION: ReactOS' Native Shell
|
* DESCRIPTION: ReactOS' Native Shell
|
||||||
|
@ -251,20 +251,22 @@ ExecuteKill(char * lpPid)
|
||||||
|
|
||||||
void ExecuteHelp (void * dummy)
|
void ExecuteHelp (void * dummy)
|
||||||
{
|
{
|
||||||
debug_printf ("A:\t\t\tCurrent drive is A:\n");
|
debug_printf (
|
||||||
debug_printf ("C:\t\t\tCurrent drive is C:\n");
|
"A:\t\t\tCurrent drive is A:\n"
|
||||||
debug_printf ("cd [directory]\t\tChange current directory\n");
|
"C:\t\t\tCurrent drive is C:\n"
|
||||||
debug_printf ("dir [directory]\t\tList directory\n");
|
"cd [directory]\t\tChange current directory\n"
|
||||||
debug_printf ("exit\t\t\tTerminate the shell\n");
|
"dir [directory]\t\tList directory\n"
|
||||||
debug_printf ("help\t\t\tPrint this help message\n");
|
"exit\t\t\tTerminate the shell\n"
|
||||||
debug_printf ("kill [pid]\t\tKill process which PID is pid\n");
|
"help\t\t\tPrint this help message\n"
|
||||||
debug_printf ("md [directory]\t\tCreate a new directory\n");
|
"kill [pid]\t\tKill process which PID is pid\n"
|
||||||
debug_printf ("reboot\t\t\tRestart the system\n");
|
"md [directory]\t\tCreate a new directory\n"
|
||||||
debug_printf ("start [program.exe]\tDetach program.exe\n");
|
"reboot\t\t\tRestart the system\n"
|
||||||
debug_printf ("type [file]\t\tPrint the file on console\n");
|
"start [program.exe]\tDetach program.exe\n"
|
||||||
debug_printf ("validate\t\tValidate the process' heap\n");
|
"type [file]\t\tPrint the file on console\n"
|
||||||
debug_printf ("ver\t\t\tPrint version information\n");
|
"validate\t\tValidate the process' heap\n"
|
||||||
debug_printf ("[program.exe]\t\tStart synchronously program.exe\n\n");
|
"ver\t\t\tPrint version information\n"
|
||||||
|
"[program.exe]\t\tStart synchronously program.exe\n\n"
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExecuteCommand(char* line)
|
void ExecuteCommand(char* line)
|
||||||
|
@ -397,43 +399,42 @@ void ReadLine(char* line)
|
||||||
{
|
{
|
||||||
DWORD Result;
|
DWORD Result;
|
||||||
UCHAR CurrentDir[255];
|
UCHAR CurrentDir[255];
|
||||||
char ch;
|
|
||||||
int length = 0;
|
int length = 0;
|
||||||
|
int c;
|
||||||
|
|
||||||
GetCurrentDirectoryA(255,CurrentDir);
|
GetCurrentDirectoryA(255,CurrentDir);
|
||||||
debug_printf("%s>", CurrentDir);
|
debug_printf("%s>", CurrentDir);
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
if (!ReadConsoleA(InputHandle,
|
if ( !ReadConsoleA(InputHandle, line, 255 - length, &Result, NULL) )
|
||||||
&ch,
|
|
||||||
1,
|
|
||||||
&Result,
|
|
||||||
NULL))
|
|
||||||
{
|
{
|
||||||
debug_printf("Failed to read from console\n");
|
debug_printf("Failed to read from console\n");
|
||||||
for(;;);
|
for(;;);
|
||||||
}
|
}
|
||||||
switch (ch)
|
for( c = 0; c < Result; c++ )
|
||||||
{
|
switch ( line[c] )
|
||||||
case '\b':
|
{
|
||||||
if (length > 0)
|
case '\b':
|
||||||
{
|
if (length > 0)
|
||||||
debug_printf("\b \b");
|
{
|
||||||
line--;
|
debug_printf("\b \b");
|
||||||
length--;
|
memmove( &line[c-1], &line[c], Result - c - 1 );
|
||||||
}
|
c-=2;
|
||||||
break;
|
length--;
|
||||||
|
Result--;
|
||||||
default:
|
}
|
||||||
*line = ch;
|
break;
|
||||||
debug_printf( "%c", ch );
|
case '\n':
|
||||||
line++;
|
line[c] = 0;
|
||||||
|
debug_printf( "\n" );
|
||||||
|
return;
|
||||||
|
default:
|
||||||
|
debug_printf( "%c", line[c] );
|
||||||
length++;
|
length++;
|
||||||
}
|
}
|
||||||
} while (ch != '\n');
|
line += Result;
|
||||||
line--;
|
} while (1);
|
||||||
*line = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ParseCommandLine (void)
|
void ParseCommandLine (void)
|
||||||
|
|
Loading…
Reference in a new issue