Problem 1 create a simple shell basically your shell should

Assignment Help Application Programming
Reference no: EM13347589

Problem 1. Create a simple shell. Basically your shell should read the line from standard input, parse the line with command and arguments, and operate the command with arguments. You'll need the fork() and exec*() system calls.

o The shell should search the command in your current working directory first. If not found, it should search the directories in the shell's pathname list which will be explained in the part 2.

o You are not allowed to use system(), as it just invokes the system's /bin/sh shell to do all the work. You are not allowed to utilize execlp() or execvp() in the standard library, because our shell has its own path variable, explained in part 2.

o You can assume that arguments are separated by white spaces. You do not have to deal with special characters such as ', ", \, etc; thus, you need to handle the redirection operators (<, >, and 2>) and the pipeline operator (|).

o You will assume that the command line a user types is no longer than 4096 bytes. Therefore, you should not assume that there is a restriction on the number of arguments to a given command.

o The executable file for your shell could be named myshell, for the TAs' grading pleasure.

Problem 2. Implement the following built-in commands.

o  exit: users can exit from the shell with the exit command.

o  cd: cd is a command to change directories. You will need to invoke the chdir system call.

o path: path is a command not only to show the current pathname list, but also to append or remove several pathnames. In your shell implementation, you may keep an variable or data structure to deal with pathname list (referred to as "path" variable below). This list helps searching for executables when users enter specific commands.

-  path (without arguments) displays the pathnames currently set. It should show pathnames separated by colons. ex) "/bin:/usr/bin"

-  path + /foo/bar appends the pathname to the "path" variable. Only one pathname will be given to each invocation of the path command. It's okay to add a pathname to the "path" variable even if it already contains the same pathname, i.e., duplicates in the "path" variable are fine.

-  path - /foo/bar removes the pathname from the "path" variable. It should remove all duplicates of the given pathname. Only one pathname will be given to each invocation of the path command.

Problem 3. (Extend your shell with I/O redirection (<, >, and 2>), as described above.

o stdin maps to file descriptor 0, stdout to 1, and stderr to 2.

o You'll need the open(), close(), and dup2() system calls.

o You can assume that there is no space inside the stderr redirection operator "2>"

o You should handle cases when all three streams are redirected, such as cmd < in.txt > out.txt 2> err.txt (not necessarily in this order).

o You don't need to handle other forms of redirections. For example, you don't need to handle the following redirections : cmd 1> filename (another way to redirect standard output)), cmd 2>&1 (redirect standard error to standard output). (Most other shells do handle the above cases.)

o Your shell do not need to handle I/O redirection for built-in commands (cd, exit, path).

Problem 4. Extend your shell with pipeline (|), as described above.

o You'll need the pipe system call.

o There is no restriction on the depth of a pipeline. That is, your solution should handle arbitrary number of commands chained together with operator |

o You should handle combinations of redirection and pipeline when they can be combined. An example is: sort < file.txt | uniq. However, if there is a conflict between redirection and pipeline, i.e. one file descriptor gets associated with two things, you should report a syntax error. An example is: ls > 1.txt | grep FOO; we cannot redirect the stdout of ls to both 1.txt and grep at the same time.

o Your shell do not need to handle built-in commands (cd, exit, path) in pipeline.

o Your shell should not accept new user commands while the pipeline is still running.

Reference no: EM13347589

Questions Cloud

Problem 1budgets in managerial accountingsantiagos salsa is : problem 1budgets in managerial accountingsantiagos salsa is in the process of preparing a production cost budget for
Johnson companys balance sheet section with intangible : johnson companys balance sheet section with intangible assets at 12312012 is presented below.costless
Question oneayou have a credit card with a stated interest : question onea.you have a credit card with a stated interest rate of 1 monthly. what is the apr?b.today you borrowed
Analog measurements prepare an assembly program for the : analog measurements prepare an assembly program for the correctly measures the wind direction to a precision of 45deg n
Problem 1 create a simple shell basically your shell should : problem 1. create a simple shell. basically your shell should read the line from standard input parse the line with
Analytical exercisescenario abc company sells widgets in : analytical exercisescenario abc company sells widgets in three varieties red yellow and blue but has lost money for
Problem 1consider that the meaning of the bun instruction : problem 1.consider that the meaning of the bun instruction of the basic computer is changed to implement the relative
1 you are a commuter student at a local university : 1. you are a commuter student at a local university. because of the steep rise in gasoline prices your parents decide
Assignment 1write a program using vectors and iterators : assignment 1write a program using vectors and iterators that allows a user to maintain a personal list of dvd titles.

Reviews

Write a Review

Application Programming Questions & Answers

  In this project you will create an application to run in

in this project you will create an application to run in the amazon ec2 service and you will also create a client that

  Imagine that your company has decided to expand to the web

imagine that your company has decided to expand to the web. you want to reuse some data entry code that has been

  1 here is a short program it prints out the value of a

1. here is a short program. it prints out the value of a variable x. ernie and bert disagree about what will be printed

  If the user wants to read the input from a file then the

if the user wants to read the input from a file then the output will also go into a different file. if the user wants

  Question 1we are given the following knowledge base of

question 1we are given the following knowledge base of travel informationnbspbycaraucklandhamilton.

  Basic requirementsscreen one has three edittext views and

basic requirementsscreen one has three edittext views and one button.the edittext views allow you to enter a students

  Create a application using the mvc architecture no

create a application using the mvc architecture. no scripting elements are allowed in jsp

  Rtl sa is a company which develops bespoke solutions for

rtl sa is a company which develops bespoke solutions for the rubber industry. they produce both rubber compound which

  Design a program that models the worms behavior in the

design a program that models the worms behavior in the subsequent scenarioa worm is moving toward an apple. each time

  Problem build a class for a type called fractionnbspthis

problem build a class for a type called fraction.nbspthis class is used to show a ration of two integers.nbsp include

  Part - 1 object-oriented designwrite a program that allows

part - 1 object-oriented designwrite a program that allows an instructor to keep a grade book. each students has scores

  Soda vending machine designnbsp design a soda vending

soda vending machine designnbsp design a soda vending machine that can deliver three kinds of soda a b and c. allnbsp

Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd