mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-24 21:45:21 +00:00
Switch virCommandRunRegex to use virStringSplit
Instead of running the command asynchronously and reading the output via fgets, let virCommand collect the output and split it with virStringSplit.
This commit is contained in:
parent
f2cc42868e
commit
7dbbad35f2
@ -2779,15 +2779,16 @@ virCommandRunRegex(virCommandPtr cmd,
|
|||||||
void *data,
|
void *data,
|
||||||
const char *prefix)
|
const char *prefix)
|
||||||
{
|
{
|
||||||
int fd = -1, err, ret = -1;
|
int err;
|
||||||
FILE *list = NULL;
|
|
||||||
regex_t *reg;
|
regex_t *reg;
|
||||||
regmatch_t *vars = NULL;
|
regmatch_t *vars = NULL;
|
||||||
char line[1024];
|
|
||||||
int maxReg = 0;
|
int maxReg = 0;
|
||||||
size_t i, j;
|
size_t i, j, k;
|
||||||
int totgroups = 0, ngroup = 0, maxvars = 0;
|
int totgroups = 0, ngroup = 0, maxvars = 0;
|
||||||
char **groups;
|
char **groups;
|
||||||
|
char *outbuf = NULL;
|
||||||
|
char **lines = NULL;
|
||||||
|
int ret = -1;
|
||||||
|
|
||||||
/* Compile all regular expressions */
|
/* Compile all regular expressions */
|
||||||
if (VIR_ALLOC_N(reg, nregex) < 0)
|
if (VIR_ALLOC_N(reg, nregex) < 0)
|
||||||
@ -2818,29 +2819,27 @@ virCommandRunRegex(virCommandPtr cmd,
|
|||||||
if (VIR_ALLOC_N(vars, maxvars+1) < 0)
|
if (VIR_ALLOC_N(vars, maxvars+1) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
virCommandSetOutputFD(cmd, &fd);
|
virCommandSetOutputBuffer(cmd, &outbuf);
|
||||||
if (virCommandRunAsync(cmd, NULL) < 0) {
|
if (virCommandRun(cmd, NULL) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
|
||||||
|
if (!outbuf) {
|
||||||
|
/* no output */
|
||||||
|
ret = 0;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((list = VIR_FDOPEN(fd, "r")) == NULL) {
|
if (!(lines = virStringSplit(outbuf, "\n", 0)))
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
||||||
"%s", _("cannot read fd"));
|
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
|
||||||
|
|
||||||
while (fgets(line, sizeof(line), list) != NULL) {
|
for (k = 0; lines[k]; k++) {
|
||||||
char *p = NULL;
|
char *p = NULL;
|
||||||
/* Strip trailing newline */
|
|
||||||
int len = strlen(line);
|
|
||||||
if (len && line[len-1] == '\n')
|
|
||||||
line[len-1] = '\0';
|
|
||||||
|
|
||||||
/* ignore any command prefix */
|
/* ignore any command prefix */
|
||||||
if (prefix)
|
if (prefix)
|
||||||
p = STRSKIP(line, prefix);
|
p = STRSKIP(lines[k], prefix);
|
||||||
if (!p)
|
if (!p)
|
||||||
p = line;
|
p = lines[k];
|
||||||
|
|
||||||
for (i = 0; i <= maxReg && i < nregex; i++) {
|
for (i = 0; i <= maxReg && i < nregex; i++) {
|
||||||
if (regexec(®[i], p, nvars[i]+1, vars, 0) == 0) {
|
if (regexec(®[i], p, nvars[i]+1, vars, 0) == 0) {
|
||||||
@ -2872,8 +2871,10 @@ virCommandRunRegex(virCommandPtr cmd,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = virCommandWait(cmd, NULL);
|
ret = 0;
|
||||||
cleanup:
|
cleanup:
|
||||||
|
virStringFreeList(lines);
|
||||||
|
VIR_FREE(outbuf);
|
||||||
if (groups) {
|
if (groups) {
|
||||||
for (j = 0; j < totgroups; j++)
|
for (j = 0; j < totgroups; j++)
|
||||||
VIR_FREE(groups[j]);
|
VIR_FREE(groups[j]);
|
||||||
@ -2885,10 +2886,6 @@ cleanup:
|
|||||||
regfree(®[i]);
|
regfree(®[i]);
|
||||||
|
|
||||||
VIR_FREE(reg);
|
VIR_FREE(reg);
|
||||||
|
|
||||||
VIR_FORCE_FCLOSE(list);
|
|
||||||
VIR_FORCE_CLOSE(fd);
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user