X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=Usermode%2FApplications%2FCLIShell_src%2Fmain.c;h=28007e12027ff90b9b9a5564a3d1c81c728188cb;hb=ee247b1e92a4a92eb0fa8f842e34e454b47b8327;hp=33907eeeb115a79e75528e5f52436829cf8555aa;hpb=fe2794b4f932c0755674493b6a6da4b60a5c2433;p=tpg%2Facess2.git diff --git a/Usermode/Applications/CLIShell_src/main.c b/Usermode/Applications/CLIShell_src/main.c index 33907eee..28007e12 100644 --- a/Usermode/Applications/CLIShell_src/main.c +++ b/Usermode/Applications/CLIShell_src/main.c @@ -7,18 +7,14 @@ #include #include #include "header.h" - -#if USE_READLINE -# include "readline.h" -#endif +#include #define _stdin 0 #define _stdout 1 #define _stderr 2 // ==== PROTOTYPES ==== -char *ReadCommandLine(int *Length); -void Parse_Args(char *str, char **dest); + int Parse_Args(const char *str, char **dest); void CallCommand(char **Args); void Command_Logout(int argc, char **argv); void Command_Clear(int argc, char **argv); @@ -49,18 +45,13 @@ char **gasCommandHistory; int giCommandSpace = 0; // ==== CODE ==== -int main(int argc, char *argv[], char *envp[]) +int main(int argc, char *argv[], char **envp) { char *sCommandStr; char *saArgs[32] = {0}; - int length = 0; int i; int iArgCount = 0; - #if !USE_READLINE - int bCached = 1; - #else tReadline *readline_state = Readline_Init(1); - #endif gasEnvironment = envp; @@ -77,51 +68,20 @@ int main(int argc, char *argv[], char *envp[]) } } - write(_stdout, 22, "Acess Shell Version 3\n"); - write(_stdout, 2, "\n"); + printf("Acess Shell Version 3\n\n"); for(;;) { // Free last command & arguments - if(saArgs[0]) free(saArgs); - #if !USE_READLINE - if(!bCached) free(sCommandStr); - bCached = 0; - #endif + if(saArgs[0]) free(saArgs[0]); - write(_stdout, strlen(gsCurrentDirectory), gsCurrentDirectory); - write(_stdout, 2, "$ "); + printf("%s$ ", gsCurrentDirectory); // Read Command line - #if USE_READLINE sCommandStr = Readline( readline_state ); - length = strlen(sCommandStr); - #else - sCommandStr = ReadCommandLine( &length ); - - if(!sCommandStr) { - write(_stdout, 25, "PANIC: Out of heap space\n"); - return -1; - } - - // Check if the command should be cached - if(gasCommandHistory == NULL || strcmp(sCommandStr, gasCommandHistory[giLastCommand]) != 0) - { - if(giLastCommand >= giCommandSpace) { - giCommandSpace += 12; - gasCommandHistory = realloc(gasCommandHistory, giCommandSpace*sizeof(char*)); - } - giLastCommand ++; - gasCommandHistory[ giLastCommand ] = sCommandStr; - bCached = 1; - } - #endif + printf("\n"); // Parse Command Line into arguments - Parse_Args(sCommandStr, saArgs); - - // Count Arguments - iArgCount = 0; - while(saArgs[iArgCount]) iArgCount++; + iArgCount = Parse_Args(sCommandStr, saArgs); // Silently Ignore all empty commands if(saArgs[1][0] == '\0') continue; @@ -140,173 +100,23 @@ int main(int argc, char *argv[], char *envp[]) // Shall we? CallCommand( &saArgs[1] ); - #if USE_READLINE free( sCommandStr ); - #endif } } /** - * \fn char *ReadCommandLine(int *Length) - * \brief Read from the command line - */ -char *ReadCommandLine(int *Length) -{ - char *ret; - int len, pos, space = 1023; - char ch; - #if 0 - int scrollbackPos = giLastCommand; - #endif - - // Preset Variables - ret = malloc( space+1 ); - if(!ret) return NULL; - len = 0; pos = 0; - - // Read In Command Line - do { - read(_stdin, 1, &ch); // Read Character from stdin (read is a blocking call) - - if(ch == '\n') break; - - switch(ch) - { - // Control characters - case '\x1B': - read(_stdin, 1, &ch); // Read control character - switch(ch) - { - //case 'D': if(pos) pos--; break; - //case 'C': if(pos 0 ) break; - - free(ret); - ret = strdup( gasCommandHistory[--scrollbackPos] ); - - len = strlen(ret); - while(pos--) write(_stdout, 3, "\x1B[D"); - write(_stdout, len, ret); pos = len; - while(pos++ < oldLen) write(_stdout, 1, " "); - } - break; - case 'B': // Down - { - int oldLen = len; - if( scrollbackPos < giLastCommand-1 ) break; - - free(ret); - ret = strdup( gasCommandHistory[++scrollbackPos] ); - - len = strlen(ret); - while(pos--) write(_stdout, 3, "\x1B[D"); - write(_stdout, len, ret); pos = len; - while(pos++ < oldLen) write(_stdout, 1, " "); - } - break; - #endif - case 'D': // Left - if(pos == 0) break; - pos --; - write(_stdout, 3, "\x1B[D"); - break; - case 'C': // Right - if(pos == len) break; - pos++; - write(_stdout, 3, "\x1B[C"); - break; - } - } - break; - - // Backspace - case '\b': - if(len <= 0) break; // Protect against underflows - write(_stdout, 1, &ch); - if(pos == len) { // Simple case of end of string - len --; - pos--; - } - else { - char buf[7] = "\x1B[000D"; - buf[2] += ((len-pos+1)/100) % 10; - buf[3] += ((len-pos+1)/10) % 10; - buf[4] += (len-pos+1) % 10; - write(_stdout, len-pos, &ret[pos]); // Move Text - ch = ' '; write(_stdout, 1, &ch); ch = '\b'; // Clear deleted character - write(_stdout, 7, buf); // Update Cursor - // Alter Buffer - memmove(&ret[pos-1], &ret[pos], len-pos); - pos --; - len --; - } - break; - - // Tab - case '\t': - //TODO: Implement Tab-Completion - //Currently just ignore tabs - break; - - default: - // Expand Buffer - if(len+1 > space) { - space += 256; - ret = realloc(ret, space+1); - if(!ret) return NULL; - } - - // Editing inside the buffer - if(pos != len) { - char buf[7] = "\x1B[000D"; - buf[2] += ((len-pos)/100) % 10; - buf[3] += ((len-pos)/10) % 10; - buf[4] += (len-pos) % 10; - write(_stdout, 1, &ch); // Print new character - write(_stdout, len-pos, &ret[pos]); // Move Text - write(_stdout, 7, buf); // Update Cursor - memmove( &ret[pos+1], &ret[pos], len-pos ); - } - else { - write(_stdout, 1, &ch); - } - ret[pos++] = ch; - len ++; - break; - } - } while(ch != '\n'); - - // Cap String - ret[len] = '\0'; - printf("\n"); - - // Return length - if(Length) *Length = len; - - return ret; -} - -/** - * \fn void Parse_Args(char *str, char **dest) + * \fn int Parse_Args(const char *str, char **dest) * \brief Parse a string into an argument array */ -void Parse_Args(char *str, char **dest) +int Parse_Args(const char *str, char **dest) { int i = 1; char *buf = malloc( strlen(str) + 1 ); if(buf == NULL) { dest[0] = NULL; - Print("Parse_Args: Out of heap space!\n"); - return ; + printf("Parse_Args: Out of heap space!\n"); + return 0; } strcpy(buf, str); @@ -333,10 +143,8 @@ void Parse_Args(char *str, char **dest) if(*buf == '\0') break; } dest[i] = NULL; - if(i == 1) { - free(buf); - dest[0] = NULL; - } + + return i; } /** @@ -357,20 +165,19 @@ void CallCommand(char **Args) { GeneratePath(exefile, gsCurrentDirectory, sTmpBuffer); // Check file existence - fd = open(sTmpBuffer, OPENFLAG_EXEC); + fd = _SysOpen(sTmpBuffer, OPENFLAG_EXEC); if(fd == -1) { - Print("Unknown Command: `");Print(Args[0]);Print("'\n"); // Error Message + printf("Unknown Command: `%s'\n", Args[0]); // Error Message return ; } // Get File info and close file - finfo( fd, &info, 0 ); - close( fd ); + _SysFInfo( fd, &info, 0 ); + _SysClose( fd ); // Check if the file is a directory if(info.flags & FILEFLAG_DIRECTORY) { - Print("`");Print(sTmpBuffer); // Error Message - Print("' is a directory.\n"); + printf("`%s' is a directory.\n", sTmpBuffer); return ; } } @@ -382,10 +189,10 @@ void CallCommand(char **Args) for( i = 0; i < giNumPathDirs; i++ ) { GeneratePath(exefile, gasPathDirs[i], sTmpBuffer); - fd = open(sTmpBuffer, OPENFLAG_EXEC); + fd = _SysOpen(sTmpBuffer, OPENFLAG_EXEC); if(fd == -1) continue; - finfo( fd, &info, 0 ); - close( fd ); + _SysFInfo( fd, &info, 0 ); + _SysClose( fd ); if(info.flags & FILEFLAG_DIRECTORY) continue; // Woohoo! We found a valid command break; @@ -393,22 +200,20 @@ void CallCommand(char **Args) // Exhausted path directories if( i == giNumPathDirs ) { - Print("Unknown Command: `");Print(exefile);Print("'\n"); + printf("Unknown Command: `%s'\n", exefile); return ; } } // Create new process - pid = clone(CLONE_VM, 0); - // Start Task - if(pid == 0) - execve(sTmpBuffer, Args, gasEnvironment); + int fds[] = {0, 1, 2}; + pid = _SysSpawn(sTmpBuffer, (const char **)Args, (const char **)gasEnvironment, 3, fds, NULL); if(pid <= 0) { - Print("Unablt to create process: `");Print(sTmpBuffer);Print("'\n"); // Error Message + printf("Unable to create process: `%s'\n", sTmpBuffer); // Error Message } else { int status; - waittid(pid, &status); + _SysWaitTID(pid, &status); } } @@ -427,17 +232,16 @@ void Command_Logout(int argc, char **argv) */ void Command_Help(int argc, char **argv) { - Print("Acess 2 Command Line Interface\n"); - Print(" By John Hodge (thePowersGang / [TPG])\n"); - Print("\n"); - Print("Builtin Commands:\n"); - Print(" logout: Return to the login prompt\n"); - Print(" exit: Same\n"); - Print(" help: Display this message\n"); - Print(" clear: Clear the screen\n"); - Print(" cd: Change the current directory\n"); - Print(" dir: Print the contents of the current directory\n"); - //Print("\n"); + printf( "Acess 2 Command Line Interface\n" + " By John Hodge (thePowersGang / [TPG])\n" + "\n" + "Builtin Commands:\n" + " logout: Return to the login prompt\n" + " exit: Same\n" + " help: Display this message\n" + " clear: Clear the screen\n" + " cd: Change the current directory\n" + " dir: Print the contents of the current directory\n"); return; } @@ -447,7 +251,7 @@ void Command_Help(int argc, char **argv) */ void Command_Clear(int argc, char **argv) { - write(_stdout, 4, "\x1B[2J"); //Clear Screen + _SysWrite(_stdout, "\x1B[2J", 4); //Clear Screen } /** @@ -462,22 +266,22 @@ void Command_Cd(int argc, char **argv) if(argc < 2) { - Print(gsCurrentDirectory);Print("\n"); + printf("%s\n", gsCurrentDirectory); return; } GeneratePath(argv[1], gsCurrentDirectory, tmpPath); - fp = open(tmpPath, 0); + fp = _SysOpen(tmpPath, 0); if(fp == -1) { - write(_stdout, 26, "Directory does not exist\n"); + printf("Directory does not exist\n"); return; } - finfo(fp, &stats, 0); - close(fp); + _SysFInfo(fp, &stats, 0); + _SysClose(fp); if( !(stats.flags & FILEFLAG_DIRECTORY) ) { - write(_stdout, 17, "Not a Directory\n"); + printf("Not a Directory\n"); return; } @@ -486,7 +290,7 @@ void Command_Cd(int argc, char **argv) strcpy(gsCurrentDirectory, tmpPath); // Register change with kernel - chdir( gsCurrentDirectory ); + _SysChdir( gsCurrentDirectory ); } /** @@ -512,7 +316,7 @@ void Command_Dir(int argc, char **argv) dirLen = strlen(tmpPath); // Open Directory - dp = open(tmpPath, OPENFLAG_READ); + dp = _SysOpen(tmpPath, OPENFLAG_READ); // Check if file opened if(dp == -1) { @@ -520,19 +324,17 @@ void Command_Dir(int argc, char **argv) return; } // Get File Stats - if( finfo(dp, &info, 0) == -1 ) + if( _SysFInfo(dp, &info, 0) == -1 ) { - close(dp); - write(_stdout, 34, "stat Failed, Bad File Descriptor\n"); + _SysClose(dp); + printf("stat Failed, Bad File Descriptor\n"); return; } // Check if it's a directory if(!(info.flags & FILEFLAG_DIRECTORY)) { - close(dp); - write(_stdout, 27, "Unable to open directory `"); - write(_stdout, strlen(tmpPath)+1, tmpPath); - write(_stdout, 20, "', Not a directory\n"); + _SysClose(dp); + printf("Unable to open directory `%s', Not a directory\n", tmpPath); return; } @@ -545,65 +347,65 @@ void Command_Dir(int argc, char **argv) fileName = (char*)(tmpPath+dirLen); // Read Directory Content - while( (fp = readdir(dp, fileName)) ) + while( (fp = _SysReadDir(dp, fileName)) ) { if(fp < 0) { if(fp == -3) - write(_stdout, 42, "Invalid Permissions to traverse directory\n"); + printf("Invalid Permissions to traverse directory\n"); break; } // Open File - fp = open(tmpPath, 0); + fp = _SysOpen(tmpPath, 0); if(fp == -1) continue; // Get File Stats - finfo(fp, &info, 0); + _SysFInfo(fp, &info, 0); if(info.flags & FILEFLAG_DIRECTORY) - write(_stdout, 1, "d"); + printf("d"); else - write(_stdout, 1, "-"); + printf("-"); // Print Mode // - Owner - acl.group = 0; acl.id = info.uid; + acl.object = info.uid; _SysGetACL(fp, &acl); if(acl.perms & 1) modeStr[0] = 'r'; else modeStr[0] = '-'; if(acl.perms & 2) modeStr[1] = 'w'; else modeStr[1] = '-'; if(acl.perms & 8) modeStr[2] = 'x'; else modeStr[2] = '-'; // - Group - acl.group = 1; acl.id = info.gid; + acl.object = info.gid | 0x80000000; _SysGetACL(fp, &acl); if(acl.perms & 1) modeStr[3] = 'r'; else modeStr[3] = '-'; if(acl.perms & 2) modeStr[4] = 'w'; else modeStr[4] = '-'; if(acl.perms & 8) modeStr[5] = 'x'; else modeStr[5] = '-'; // - World - acl.group = 1; acl.id = -1; + acl.object = 0xFFFFFFFF; _SysGetACL(fp, &acl); if(acl.perms & 1) modeStr[6] = 'r'; else modeStr[6] = '-'; if(acl.perms & 2) modeStr[7] = 'w'; else modeStr[7] = '-'; if(acl.perms & 8) modeStr[8] = 'x'; else modeStr[8] = '-'; - write(_stdout, 10, modeStr); - close(fp); + printf(modeStr); + _SysClose(fp); // Colour Code if(info.flags & FILEFLAG_DIRECTORY) // Directory: Green - write(_stdout, 6, "\x1B[32m"); + printf("\x1B[32m"); // Default: White // Print Name - write(_stdout, strlen(fileName), fileName); + printf("%s", fileName); // Print slash if applicable if(info.flags & FILEFLAG_DIRECTORY) - write(_stdout, 1, "/"); + printf("/"); // Revert Colour - write(_stdout, 6, "\x1B[37m"); + printf("\x1B[37m"); // Newline! - write(_stdout, 1, "\n"); + printf("\n"); } // Close Directory - close(dp); + _SysClose(dp); }