如何添加'&'在虚拟shell中在后台运行程序的功能?

时间:2013-11-21 18:11:29

标签: c shell command-line background

我知道我必须fork()但是之后该怎么办?另外我知道我必须在某个时候跳过wait()调用,但是我该如何实现呢?当我键入'&'在命令之后它说“无法访问&:没有这样的文件或目录”。如果&和/或者虚拟外壳应该立即返回一个提示用户的更多命令输入。在程序及其参数之后键入(因为程序将在后台运行)。我该如何做到这一点?

以下是我非常确定需要更改的代码:

pid = fork();

    if (pid){      
        wait(&retStatus);
    }

    else {
        if( execvp(args[0], args)) {
      fprintf(stderr, "%s\n", strerror(errno));
            exit(127);
        }
    }

以下是我的所有代码:

#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <string.h>
#include <unistd.h>
#include <sys/wait.h>
#define BUFFER_SIZE 1<<16
#define ARRAY_SIZE 1<<16

static void parseCmdArgs(char *buffer, char** cmdArgs, 
                size_t cmdArgsSize, size_t *nargs)
{
    char *bufCmdArgs[cmdArgsSize]; 
    char **temp;
    char *buf;
    size_t n, p;

    cmdArgs[0] = buf = bufCmdArgs[0] = buffer;  

    for(temp=bufCmdArgs; (*temp=strsep(&buf, " \n\t")) != NULL ;){
        if ((*temp != '\0') && (++temp >= &bufCmdArgs[cmdArgsSize]))
            break;
    }

    for (p=n=0; bufCmdArgs[n]!=NULL; n++){
        if(strlen(bufCmdArgs[n])>0)
            cmdArgs[p++]=bufCmdArgs[n];
    }

    *nargs=p;
    cmdArgs[p]=NULL;
}
  //int main(int argc, char *argv[], char *envp[]){
int main(void)
{
    char buffer[BUFFER_SIZE];
    char *args[ARRAY_SIZE];
    int retStatus;
    size_t nargs;
    pid_t pid;

    printf("$dummyshell\n");
    while(1){

        printf("> ");
        fgets(buffer, BUFFER_SIZE, stdin);
        parseCmdArgs(buffer, args, ARRAY_SIZE, &nargs); 


        if (nargs==0)
            continue;

        if (!strcmp(args[0], "help"))
        {
            printf("cat                    cd (absolute path references only\n");
            printf("exit\n");
            printf("help                   history\n");
            printf("jobs                   kill\n");
            printf("ls                     more\n");
            printf("ps                     pwd\n");
            continue;
        }

        if (!strcmp(args[0], "exit" ))
            exit(0);

    pid = fork();

        if (pid){      
            wait(&retStatus);
        }

        else {
            if( execvp(args[0], args)) {
          fprintf(stderr, "%s\n", strerror(errno));
                exit(127);
            }
        }
    /*  pid = fork();
    if (pid == 0)
      setpgrp();
    else if (pid)
      pid = wait(&retStatus);
    else {
      if (execvp(args[0], args)){
        fprintf(stderr, "%s\n", strerror(errno));
        exit(127);
      }
      }*/

    }    
    return 0;
}

0 个答案:

没有答案