C/C++ 编程代写
当前位置:以往案例 > >案例c语言/c++ Systems Programming shell案例
2019-02-05

Systems Programming
project 3 – Improving a Shell



Due date 11:59pm – Wednesday Week 13.
在此这个案例c语言中,您应该采用shell程序的现有实现并添加一些小的改进,在开始案例c语言的时候,Improving a Shell是本次案例c语言的主题。

Preparation – Downloading, Compiling and Testing a simple Shell Implementation

Download and un-compress the following file:
shell.tgz

The contents of the file are C sources that implement a simple shell. The contents are:

smsh.c – an implementation of a very simple shell program
smsh.h – a header file with function prototypes
execute.c – a set of helper functions for running processes within the program
splitline.c – some text processing utilities
compile these sources run:

gcc -o smsh1 smsh1.c splitline.c execute.c
To run the shell type:

./smsh1
A prompt of the form “>” will appear and then you can type commands like:

> ls

execute.c shell.tgz smsh.h smsh1 smsh1.c splitline.c

> wc execute.c

37 113 725 execute.c
The shell is terminated by typing the Control-D key (which signals end of input).

In this project you shall add functionality to this shell command. Each part builds upon the last.



Part 1 – Adding the ability to pipe commands to your shell (30 marks)
At the moment smsh1 doesn’t support piping of commands. So, for ple, if you type:

ls | wc
at the prompt you get:

ls: wc: No such file or directory ls: |: No such file or directory
Write a new program called smsh2.c that is based on smsh1.c which performs all of the shell operations of smsh1.c but also allows commands to be piped as above so that if you type:

ls | wc
You get output like:

6 6 53
instead. You are free to add and modify files as required to accomplish this task. You must add a Makefile to your submission so that you can compile all the files for part1 by typing:

make part1
and the solution for part 1 can be run by typing:

./smsh2
Note, your program must still cater for all the behaviours that were correct in the original version of smsh1. You may find the lectures on piping useful in completing this part.

Part 2 – redirecton of stdin and stdout (30 Marks)
Your version of smsh2 currently doesn’t support redirection of output and input of commands such as:

ls > tmp.txt

cat < tmp.txt | wc > out.txt
Copy your smsh2.c program from part 1 to smsh3.c so that it can handle redirection of standard input and standard output (don’t worry about stderr) using the “>” and “<” symbols. Again, you are free to add and modify files as required to accomplish this task (without affecting the ability of your code to correctly execute the behaviour required for part 1). You must add a Makefile to your submission so that you can compile all the files for part 2 by typing:

make part2
and the solution for part 2 can be run by typing:

./smsh3
Note, your program must still cater for all the behaviours that were correct in the original version of smsh2.



Part 3 – Adding Globbing – (20 marks)
Your version of smsh3 currently doesn’t support wildcards in command lines such as:

ls *.c cat *.h
Copy your smsh3.c program from part 2 to smsh4.c so that it can handle wilcard symbols in the command line. This expansion of wildcards is called globbing.

Note, you can use the glob system call (type “man -s3 glob” to find out more) that helps you to expand the wildcards to a list of actual filenames.

Again, you are free to add and modify files as required to accomplish this task (without affecting the ability of your code to correctly execute the behaviour required for previous parts). You must add a Makefile to your submission so that you can compile all the files for part3 by typing:

make part3
and the solution for part 3 can be run by typing:

./smsh4
Note, your program must still cater for all the behaviours that were correct in the original version of smsh3.

Detailed Submission Instructions
This project is basically like every other project you’ve ever done in CS… but just as a reminder:

The handin key for this exercise is: prac3. The following SVN commands will enable you to make a repository for this project. Please note the following:

Perform these steps in the order written onceonly!
Replace aaaaaa, where it appears in the commands, with YOUR student
Some commands are long — they must be typed on one


Use the Unix “cd” command to change to the place where you want your exercise directory to be stored, then type these commands:

svn mkdir –parents -m “spc prac3 start” https://version- control.adelaide.edu.au/svn/a1aaaaaa/2018/s1/spc/prac3

(creates this directory in your svn tree)

svn co https://version-control.adelaide.edu.au/svn/a1aaaaaa/2018/s1/spc/prac3 . (checks out a working copy in your directory) You can now begin work.

You can add a file to the repository by typing the commands: svn add NAME-OF-FILE

svn commit -m “REASON-FOR-THE-COMMIT”

where “reason-for-the-commit” should be some brief text that explains why you changed the code since the last commit. Note that you only need to add a file once

— after that, SVN will “know” it is in the repository. You are now ready to commence working on the exercise.

The files you handin must include:



Your C source files as specified
A Makefile that will compile your C sources as specified


You do not have to include any of the add_one.c files or their variants… that you used for testing we will supply those.

Make sure you commit your files frequently, in case you have an accident. The University’s SVN repository is very reliable, and is backed up regularly — your computer probably is not… Regular submission is also a good defence against plagiarism by others, since the submissions are dated. We will test the behaviour of your scripts using an automated tester. The tester is thorough, and will find places where your scripts do not work correctly. If it finds an error, it will offer a (vaguish) hint. To encourage you to test your own work, the tester will not be fully available in the first few days before the exercise deadline.

The websubmission system will award up to 6 marks automatically. We will manually check the code for style and commenting and for code associated with the optional bonus exercise. Note that we reserve the right to deduct marks if your code does anything egregious or games the system to obtain marks.

End of project Specification

更多案例c语言的讯息请点击这里!

在线提交订单