Захват стандартного вывода syscall без записи в файл на C / C ++ - PullRequest
1 голос
/ 09 июля 2009

Я хочу прочитать вывод std системного вызова в строку C / C ++. Могу ли я сделать это без использования временного файла?

Perl

//without file io
$output = `echo hello`;

C ++

//with file io
system ("echo hello > tmp");
std::fstream file ("tmp");
std::string s;
file >> s;

Ответы [ 2 ]

2 голосов
/ 09 июля 2009

Использование C popen (возможно, самое простое решение, даже если оно не использует C ++ iostream):

FILE *p = popen("echo hello", "r");
std::string s;
for (size_t count; (count = fread(buf, 1, sizeof(buf), p));)
    s += string(buf, buf + count);
pclose(p);

Предполагая, что ваш iostream имеет нестандартный x fstream:: x fstream(int fd) конструктор:

FILE *p = popen("echo hello", "r");
std::ifstream p2(fileno(p));
std::string s;
p2 >> s;
p2.close();
pclose(p);

Используя Boost.Iostreams , вам не нужно зависеть от нестандартных расширений iostream:

boost::iostreams::file_descriptor_source p2(fileno(p));

К сожалению, Windows ужасна и _popen работает только для консольных приложений; для графического приложения:

SECURITY_ATTRIBUTES sec;
sec.nLength = sizeof(sec);
sec.bInheritHandle = TRUE;
sec.lpSecurityDescriptor = NULL;
HANDLE *h[2];
CreatePipe(&h[0], &h[1], &sec, 0);
SetHandleInformation(h[0], HANDLE_FLAG_INHERIT, 0)
STARTUPINFO si;
memset((void *)&si, 0, sizeof(si));
si.hStdInput = INVALID_HANDLE_VALUE;
si.hStdOutput = h[1];
si.hStdError = INVALUD_HANDLE_VALUE;
si.dwFlags |= STARTF_USESTDHANDLES;
CreateProcess(NULL, "cmd /c \"echo hello\"", NULL, NULL, TRUE, 0, NULL, NULL, &si, NULL);
boost::iostreams::file_descriptor_source p(h[0]);

(полностью не проверено)

0 голосов
/ 09 июля 2009

Это может помочь вам перенаправить стандартный вывод из системного вызова.

...