Что такое кроссплатформенный способ получить текущий каталог? - PullRequest
17 голосов
/ 19 мая 2010

Мне нужен кроссплатформенный способ получить текущий рабочий каталог (да, getcwd делает то, что я хочу). Я думал, что это может помочь:

#ifdef _WIN32
    #include <direct.h>
    #define getcwd _getcwd // stupid MSFT "deprecation" warning
#elif
    #include <unistd.h>
#endif
#include <string>
#include <iostream>
using namespace std;

int main()
{
    string s_cwd(getcwd(NULL,0));
    cout << "CWD is: " << s_cwd << endl;
}

Я получил это чтение:

Не должно быть утечек памяти, и это должно работать и на Mac, правильно?

ОБНОВЛЕНИЕ: я боюсь, что здесь все еще что-то не так (я пытаюсь избежать создания массива char с определенной длиной, так как нет правильного способа получить приличную длину для getcwd):

char* a_cwd = getcwd(NULL,0);
string s_cwd(a_cwd);
free(a_cwd); // or delete a_cwd? 

Ответы [ 3 ]

25 голосов
/ 19 мая 2010

Если для вас нет проблем с включением, используйте boost файловой системы для удобных операций кроссплатформенной файловой системы.

boost::filesystem::path full_path( boost::filesystem::current_path() );

Вот пример .

РЕДАКТИРОВАТЬ: как отметил Рой Дантон в комментариях, файловая система стала частью ISO C ++ в C ++ 17 , поэтому повышение больше не требуется:

std::filesystem::current_path();
14 голосов
/ 19 мая 2010

Вы не можете вызвать getcwd с пустым буфером.Согласно Opengroup :

Если buf является нулевым указателем, поведение getcwd () не определено.

Кроме того, getcwd может вернутьNULL, который может сломать строковый конструктор.

Вам нужно изменить это на что-то вроде:

char buffer[SIZE];
char *answer = getcwd(buffer, sizeof(buffer));
string s_cwd;
if (answer)
{
    s_cwd = answer;
}
2 голосов
/ 19 мая 2010

Вызов getcwd с указателем NULL определяется реализацией. Это часто делает распределение для вас с помощью malloc (в этом случае ваш код имеет утечку памяти). Тем не менее, это вовсе не гарантирует работу. Так что вы должны выделить свой собственный буфер.

char *cwd_buffer = malloc(sizeof(char) * max_path_len);
char *cwd_result = getcwd(cwd_buffer, max_path_len);

В Open Group есть пример, показывающий, как получить максимальную длину пути из _PC_PATH_MAX. Вы можете использовать MAX_PATH в Windows. См. этот вопрос , чтобы узнать об этом номере на обеих платформах.

...