va_end(ap);
}
-void argv_array_clear(struct argv_array *array)
+void argv_array_pushv(struct argv_array *array, const char **argv)
{
- if (array->argv != empty_argv) {
- int i;
- for (i = 0; i < array->argc; i++)
- free((char **)array->argv[i]);
- free(array->argv);
- }
- argv_array_init(array);
+ for (; *argv; argv++)
+ argv_array_push(array, *argv);
}
-const char **argv_array_detach(struct argv_array *array, int *argc)
+void argv_array_pop(struct argv_array *array)
{
- const char **argv =
- array->argv == empty_argv || array->argc == 0 ? NULL : array->argv;
- if (argc)
- *argc = array->argc;
- argv_array_init(array);
- return argv;
+ if (!array->argc)
+ return;
+ free((char *)array->argv[array->argc - 1]);
+ array->argv[array->argc - 1] = NULL;
+ array->argc--;
}
-void argv_array_free_detached(const char **argv)
+void argv_array_clear(struct argv_array *array)
{
- if (argv) {
+ if (array->argv != empty_argv) {
int i;
- for (i = 0; argv[i]; i++)
- free((char **)argv[i]);
- free(argv);
+ for (i = 0; i < array->argc; i++)
+ free((char *)array->argv[i]);
+ free(array->argv);
}
+ argv_array_init(array);
}