扩展C-Shell程序并且chdir()不能正常工作

时间:2014-11-05 02:48:50

标签: c shell

我的讲师给了我们一个用C扩展的基本shell,我正在努力让shell在用户在命令行输入“cd [directory]”时更改目录。我已经得到它来阻止段错误,但它不会改变目录。谁能告诉我它为什么不起作用?

到目前为止,这是我的代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/wait.h>

/* Array holds arguments: args[0] is the command. */
static char *args[512];
pid_t pid;
int command_pipe[2];

#define READ  0
#define WRITE 1


int chdir(const char* path);



static int
command (int input, int first, int last)
{
  int pipettes[2];

  /* Invoke pipe */
  pipe (pipettes);
  pid = fork ();

  if (pid == 0)
    {
      if (first == 1 && last == 0 && input == 0)
    {
      // 1st cmd
      dup2 (pipettes[WRITE], STDOUT_FILENO);
    }
      else if (first == 0 && last == 0 && input != 0)
    {
      // Mid cmd
      dup2 (input, STDIN_FILENO);
      dup2 (pipettes[WRITE], STDOUT_FILENO);
    }
      else
    {
      // Last cmd
      dup2 (input, STDIN_FILENO);
    }

      if (execvp (args[0], args) == -1)
    _exit (EXIT_FAILURE);   // If child fails
    }

  if (input != 0)
    close (input);

  close (pipettes[WRITE]);

  // If last command, nothing more needs to be read
  if (last == 1)
    close (pipettes[READ]);

  return pipettes[READ];
}

static void
cleanup (int n)
{
  int i;
  for (i = 0; i < n; ++i)
    wait (NULL);
}

static int go (char *cmd, int input, int first, int last);
static char line[1024];
static int n = 0;

int
main (int argc, char* argv[])
{
  while (1)
    {
      /* Initial Prompt */
      printf ("?> ");
      fflush (NULL);

      /* Read in command */
      if (!fgets (line, 1024, stdin))
    return 0;



      int input = 0;
      int first = 1;

      char *cmd = line;
      char *next = strchr (cmd, '|');   /* Find initial '|' */
      char *also = strchr (cmd, ';');   /* Find initial ';' */
      char *directory = argv[1];

      while (next != NULL)
    {
      /* 'next' points to '|' */
      *next = '\0';
      input = go (cmd, input, first, 0);

      cmd = next + 1;
      next = strchr (cmd, '|'); /* Find next '|' */
      first = 0;
    }

      if(argv[0] == "cd"){
        chdir(directory);
    }

      input = go (cmd, input, first, 1);
      cleanup (n);
      n = 0;
    }
  return 0;
}

static char *
skip_white_space (char *s)
{
  while (isspace (*s))
    ++s;
  return s;
}

static void
parse (char *cmd)
{
  cmd = skip_white_space (cmd);
  char *next = strchr (cmd, ' ');
  int i = 0;

  while (next != NULL)
    {
      next[0] = '\0';
      args[i] = cmd;
      ++i;
      cmd = skip_white_space (next + 1);
      next = strchr (cmd, ' ');
    }

  if (cmd[0] != '\0')
    {
      args[i] = cmd;
      next = strchr (cmd, '\n');
      next[0] = '\0';
      ++i;
    }

  args[i] = NULL;
}


static int
go (char *cmd, int input, int first, int last)
{
  parse (cmd);
  if (args[0] != NULL)
    {
      if (strcmp (args[0], "exit") == 0)
    exit (0);
      n += 1;
      return command (input, first, last);
    }
  return 0;
}

1 个答案:

答案 0 :(得分:4)

你眼前的问题似乎就在这里:

if(argv[0] == "cd"){
    chdir(directory);

我认为您会发现argv[0]是您的程序名称的实现代表,不是您刚输入的命令,可能在{{ 1}}。或args。或者在某个地方。

即使您解决了这个问题,也不应该使用cmd进行C中的字符串比较。==系列中的一个是正确的方法。