1

我正在尝试使用以下代码获取父目录的名称:

dirp=opendir(cur_spot);
printf("parent name: %s\n", readdir(dirp)->d_name);
closedir(dirp);

cur_spot 持有'..'。

我在一个循环中执行此操作,它不断将目录爬升到根目录,我的输出顺序是:

.
.bash_logout
.
.
srv

我知道它正在正确遍历,因为我正在检查沿途的 inode。

我需要使用不同于 d_name 的东西吗?

谢谢

4

2 回答 2

2

我根据 sjs 回答下评论中的想法提出了这个问题:

#include <dirent.h>
#include <stdio.h>
#include <assert.h>
#include <string.h>
#include <sys/stat.h>
#include <limits.h>
#include <errno.h>

int LookupName(const char* parent, ino_t ino, char *name, size_t size)
{
  DIR *dp = opendir(parent);
  if (!dp) return -1;

  int ret = -1;
  struct dirent *de;
  while (de = readdir(dp))
  {
    if (de->d_ino == ino)
    {
      strncpy(name, de->d_name, size);
      ret = 0;
      break;
    }
  }

  closedir(dp);
  if (ret == -1) errno = ENOENT;
  return ret;
}

int GetWorkdir(char *workdir, size_t size)
{
  struct stat st;
  if (stat(".", &st)) return -1;

  char path[PATH_MAX];
  strncpy(path, "..", sizeof(path));

  memset(workdir, '\0', sizeof(workdir));

  char name[PATH_MAX];
  while (1)
  {
    if (LookupName(path, st.st_ino, name, sizeof(name))) return -1;
    if (!strcmp(name, "..") || !strcmp(name, "."))
    {
      strncpy(name, "/", sizeof(name));
      strncat(name, workdir, sizeof(name));
      strncpy(workdir, name, size);
      break;
    }

    if (workdir[0] != '\0')
    {
      strncat(name, "/", sizeof(name));
    }

    strncat(name, workdir, sizeof(name));
    strncpy(workdir, name, size);

    if (stat(path, &st)) return -1;

    strncat(path, "/..", sizeof(path));
  }

  return 0;
}

int main(int argc, char **argv)
{
  char workDir[PATH_MAX];

  assert(!GetWorkdir(workDir, sizeof(workDir)));
  printf("%s\n", workDir);
}
于 2012-12-07T05:56:32.430 回答
0

readdir正在读取目录,所以当你说

printf("parent name: %s\n", readdir(dirp)->d_name);

您实际上是要求..为您打印内部第一个条目的名称,而不是..目录的名称。

根据您要执行的操作,也许解析的输出getcwd可能是更好的方法?

于 2012-12-07T04:17:34.197 回答