$30
General rules: Create homework, compose specifications or any text by using a common document-creation tool, such as Microsoft® Word.
Hints: Refer to the wwweb or lecture notes for this class to design, implement, and debug correctly working SW solutions. Be concise, complete, and precise.
Abstract: Design, implement, explain, test, and debug a simple, but complete command-line interpreter named cli.
Detail: Design, implement, document, test and run a simple shell, known here as a command-line interpreter (cli). This tool is invoked via the cli command plus possible arguments. Commands are OS commands to be executed. Multiple commands are separated from one another by commas, and each may in turn require further arguments. Cli ‘knows’ a list of commands a-priori; they are predefined. When invoked, cli checks, whether the first argument is an included command. If so, cli confirms this via a brief message. If not, a contrary message is emitted, stating this is not one the predefined commands. After the message, cli executes all commands in the order listed. After executing the last command, cli prints the current working directory, i.e. it acts as if the pwd command had been issued. Sample runs are shown further below.
Multiple commands of cli must be separated from one another by commas. Possible parameters of any one command are separated from the command itself (and from possible further parameters) by white space. White space consists of blanks, tabs, or a combination, but at least 1 blank space. Here some sample runs with single and multiple commands; outputs are not shown here:
./cli pwd -- looks like Unix command pwd; is your SW
./cli rm –f temp, mv temp ../temp1 -- ditto: input to your running homework 5
./cli ls –la -- another “single unix command”
./cli rm a.out, gcc sys.c, cp a.out cli
Cli starts out identifying itself, also naming you the author, and the release date. Then cli prints the list of all predefine commands. Finally, cli executes all commands input after the cli invocation. For your own debug effort, test your solution with numerous correct and also wrong inputs, including commas omitted, multiple commas, leading commas, illegals commands, other symbols instead of commas etc. No need to show or hand-in your test and debug work.
The output of the cli command “cli pwd” or “./cli pwd” should be as shown below, assuming your current working directory is ./classes_Sac_State/csc139. Here is the output of a sample run with a single command line argument:
herbertmayer$ ./cli pwd
hgm cli 4/12/2020
Legal commands: cd exec exit gcc ls man more mv rm pwd sh touch which $path
2 strings passed to argv[]
next string is 'pwd'
new string is 'pwd '
1st cmd 'pwd' is one of predefined.
/Users/herbertmayer/herb/academia/classes_Sac_State/csc139
Here the output of another sample run, also with a single cli command:
herbertmayer$ ./cli ls
hgm cli 4/12/2020
Legal commands: cd exec exit gcc ls man more mv rm pwd sh touch which $path
2 strings passed to argv[]
next string is 'ls'
new string is 'ls '
1st cmd 'ls' is one of predefined.
admin cli.c sac_state_yyy
backup_1_24_2020 docs sac_state_hw
backup_3_9_2020 grades sac_state_xxx
cli l_notes
/Users/herbertmayer/herb/academia/classes_Sac_State/csc139
Interpretation of commands that cli handles can proceed through system(), executed from inside your C/C++ program cli.
List of all commands supported by your cli:
char * cmds[ ] = {
"cd",
"exec",
"exit",
"gcc",
"ls",
"man",
"more",
"mv",
"rm",
"pwd",
"sh",
"touch",
"which",
"$path"
};
What you turn in:
The source program of your homework solution; well commented, preferably one single source file.
Four progressively more complex executions of your correctly working cli program, showing all user inputs and corresponding output responses.