Discuss about the i-o redirection in c shell

Assignment Help Operating System
Reference no: EM132084608

I/O redirection in C shell

Please implement input / output redirection in the code posted below. Here are the specs:

Your shell will need to support file redirection. Use the same syntax as defined in the Bash shell: a single '>' implies that one needs to redirect the standard output of the program being started to the referenced file while a single '<' implies the same with standard input. The double '>>' implies that standard output will append to an existing file rather than create a new file (similar behavior is required for the '<<' operator and standard input).

You do not need to implement support for the Bash pipeline operator '|'.

Before calling exec to begin execution, the child process may have to close stdin (file desriptor 0) and/or stdout (file descriptor 0), open the corresponding file and use the dup2 system call to make it the appropriate file descriptor.

Don't forget to use the close system call to close the old file descriptor.

#include <iostream>
#include <string>
#include <vector>
#include <unistd.h>
#include <sys/types.h>
#include <sys/wait.h>

using namespace std;

int change_dir(char* args[])
{
if (args[1] == NULL)
{
chdir(getenv("HOME"));
return 1;
}

else
{
if (chdir(args[1]) == -1)
{
cout << "No such directory" << args[1];
return -1;
}
}
return 0;
}

int helper_func(char* args[])
{
cout << "Builtin commands so far are; cd, and help.\n";

return 0;
}

int main()
{
while(true)
{
cout << "$ ";
char cmd[128];
cin.getline(cmd,128);

vector <char*> args;
char *line = strtok(cmd, " ");
char *tmp = line;
while (tmp != NULL)
{
args.push_back(tmp);
tmp = strtok(NULL, " ");
}

char** argv = new char*[args.size() + 1];
for (int i = 0; i < args.size(); i++)
argv[i] = args[i];

argv[args.size()] = NULL;


if (strcmp(cmd, "exit") == 0)
{
{
exit(0);
}
}

//else if (strcmp(args[0], "cd") == 0) change_dir(args);

if (strcmp(cmd, "cd") == 0)
{
change_dir(argv);
}

if (strcmp(cmd, "help") == 0)
{
helper_func(argv);
}

else
{
pid_t pid;
pid_t wpid;
int status;
pid = fork();
if (pid == 0)
{
if (execvp(args[0], argv) == -1)
{
perror("cmd");
}
exit(EXIT_FAILURE);
}
else if (pid < 0)
{
perror("cmd");
}
{
do {
wpid = waitpid(pid, &status, WUNTRACED);
} while (!WIFEXITED(status) && !WIFSIGNALED(status));
}
}
}
signal(SIGINT, SIG_IGN);
signal(SIGTERM, SIG_DFL);

return 0;
}

Reference no: EM132084608

Questions Cloud

Create three variables of string data type : Create three variables of String data type, called firstName, lastName, and fullName respectively; Assign your first name to the variable firstName;
Securing control of the spice islands : What European power ended up securing control of the Spice Islands (Indonesia)?
What are the key features of an oodbms : How does an object-oriented database management system (OODMS) compare to a relational database management system (RDBMS)?
What was the predominant sector of the growing manufacturing : What was the predominant sector of the growing manufacturing economy of the 16th century? Name two regional centers of this industry.
Discuss about the i-o redirection in c shell : Your shell will need to support file redirection. Use the same syntax as defined in the Bash shell: a single '>' implies that one needs to redirect.
One primary-one secondary source : Please Explain Reasoning & Use One Primary & One Secondary Source. In Chicago Style Format.
Prepare flexible budgets based on the assumptions : Prepare flexible budgets based on the assumptions of service levels at 49,000 hours, 53,000 hours, and 57,000 hours
Contribute to a vision of the physical : How did the traditions of NEOPLATONISM, RENAISSANCE, and HUMANISM contribute to a vision of the physical world that encouraged scientific investigation
Determine positive normalized floating point numbers : Determine (show your work) the smallest and largest positive normalized floating-point numbers (in decimal value) as well as the machine epsilon.

Reviews

Write a Review

Operating System Questions & Answers

  Implementation of algorithms for process management

The Shortest Job Next (SJN) algorithm queues processes in a way that the ones that use the shortest CPU cycle will be selected for running rst.

  Develop a user mode command interpreter

Develop a user mode command interpreter which support list-short.

  Memory allocation in operating system

Analysis and implementation of algorithms for memory allocation in operating system, Explain First- t and best- t methods are used in memory allocation in operating systems.

  Stand alone child process

Forking the child process

  Write a multi-threaded program

Write a multi-threaded program to solve producer and consumer problem

  Marginal and average cost curves

n a competitive market place (pure competition) is it possible to continually sell your product at a price above the average cost of production.

  Simulating operating systems scheduling

Simulate the long-term scheduler, the short-term scheduler and the I/O scheduler of the computer using the First-Come-First-Serve algorithm.

  Issues with trusted platform module

Research paper discussing the issues with Trusted Platform Module (TPM)

  Threads

Explain a complication that concurrent processing adds to an operating system.

  Design and programming

Use the semaphore methods to control the concurrency of the solution

  Virtual machines

Virtual machines supported by a host operating system

  Discuss an application that benefits barrier synchronization

Discuss an application that would benefit from the use of barrier synchronization

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