Ոգեշնչված bmorin-ի փորձից, բայց աշխատում և փորձարկված՝ այս հատվածը կվերցնի char* հրամանը և կվերադարձնի char*, որը պարունակում է այդ հրամանի կատարման արդյունքները...
// Calling function must free the returned result.
char* exec(const char* command) {
FILE* fp;
char* line = NULL;
// Following initialization is equivalent to char* result = ""; and just
// initializes result to an empty string, only it works with
// -Werror=write-strings and is so much less clear.
char* result = (char*) calloc(1, 1);
size_t len = 0;
fflush(NULL);
fp = popen(command, "r");
if (fp == NULL) {
printf("Cannot execute command:\n%s\n", command);
return NULL;
}
while(getline(&line, &len, fp) != -1) {
// +1 below to allow room for null terminator.
result = (char*) realloc(result, strlen(result) + strlen(line) + 1);
// +1 below so we copy the final null terminator.
strncpy(result + strlen(result), line, strlen(line) + 1);
free(line);
line = NULL;
}
fflush(fp);
if (pclose(fp) != 0) {
perror("Cannot close stream.\n");
}
return result;
}
Ես նայեցի պարզապես bmorin-ի կոդը խմբագրելուն, բայց ստիպված կլինեի փոխել տողերի մեծ մասը, ուստի առանձին պատասխանը ավելի տեղին էր թվում: Ներողություն, եթե ոչ: (Ի թիվս այլ խնդիրների, bmorin-ի կոդը իրականում չի կուտակել տողերը, այն տպել է դրանք stdout-ում, որտեղ ես ենթադրում եմ, որ նրանք չեն ցանկանա, քանի որ system()-ը դա կանի, և այն անվավեր է վերադարձել մեկ սխալի ճանապարհով, երբ Ֆունկցիան պետք է վերադարձնի char*, որպեսզի կոդը չկազմվի: Ամենակարևորը, թերևս, այն ազատեց արդյունքը այն վերադարձնելուց անմիջապես առաջ:)
13.02.2014