mirror of
https://github.com/git/git.git
synced 2024-11-24 10:26:17 +08:00
530f237500
A GSoC project. * fa/remote-svn: Add a test script for remote-svn remote-svn: add marks-file regeneration Add a svnrdump-simulator replaying a dump file for testing remote-svn: add incremental import remote-svn: Activate import/export-marks for fast-import Create a note for every imported commit containing svn metadata vcs-svn: add fast_export_note to create notes Allow reading svn dumps from files via file:// urls remote-svn, vcs-svn: Enable fetching to private refs When debug==1, start fast-import with "--stats" instead of "--quiet" Add documentation for the 'bidi-import' capability of remote-helpers Connect fast-import to the remote-helper via pipe, adding 'bidi-import' capability Add argv_array_detach and argv_array_free_detached Add svndump_init_fd to allow reading dumps from arbitrary FDs Add git-remote-testsvn to Makefile Implement a remote helper for svn in C
91 lines
1.8 KiB
C
91 lines
1.8 KiB
C
#include "cache.h"
|
|
#include "argv-array.h"
|
|
#include "strbuf.h"
|
|
|
|
const char *empty_argv[] = { NULL };
|
|
|
|
void argv_array_init(struct argv_array *array)
|
|
{
|
|
array->argv = empty_argv;
|
|
array->argc = 0;
|
|
array->alloc = 0;
|
|
}
|
|
|
|
static void argv_array_push_nodup(struct argv_array *array, const char *value)
|
|
{
|
|
if (array->argv == empty_argv)
|
|
array->argv = NULL;
|
|
|
|
ALLOC_GROW(array->argv, array->argc + 2, array->alloc);
|
|
array->argv[array->argc++] = value;
|
|
array->argv[array->argc] = NULL;
|
|
}
|
|
|
|
void argv_array_push(struct argv_array *array, const char *value)
|
|
{
|
|
argv_array_push_nodup(array, xstrdup(value));
|
|
}
|
|
|
|
void argv_array_pushf(struct argv_array *array, const char *fmt, ...)
|
|
{
|
|
va_list ap;
|
|
struct strbuf v = STRBUF_INIT;
|
|
|
|
va_start(ap, fmt);
|
|
strbuf_vaddf(&v, fmt, ap);
|
|
va_end(ap);
|
|
|
|
argv_array_push_nodup(array, strbuf_detach(&v, NULL));
|
|
}
|
|
|
|
void argv_array_pushl(struct argv_array *array, ...)
|
|
{
|
|
va_list ap;
|
|
const char *arg;
|
|
|
|
va_start(ap, array);
|
|
while((arg = va_arg(ap, const char *)))
|
|
argv_array_push(array, arg);
|
|
va_end(ap);
|
|
}
|
|
|
|
void argv_array_pop(struct argv_array *array)
|
|
{
|
|
if (!array->argc)
|
|
return;
|
|
free((char *)array->argv[array->argc - 1]);
|
|
array->argv[array->argc - 1] = NULL;
|
|
array->argc--;
|
|
}
|
|
|
|
void argv_array_clear(struct argv_array *array)
|
|
{
|
|
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);
|
|
}
|
|
|
|
const char **argv_array_detach(struct argv_array *array, int *argc)
|
|
{
|
|
const char **argv =
|
|
array->argv == empty_argv || array->argc == 0 ? NULL : array->argv;
|
|
if (argc)
|
|
*argc = array->argc;
|
|
argv_array_init(array);
|
|
return argv;
|
|
}
|
|
|
|
void argv_array_free_detached(const char **argv)
|
|
{
|
|
if (argv) {
|
|
int i;
|
|
for (i = 0; argv[i]; i++)
|
|
free((char **)argv[i]);
|
|
free(argv);
|
|
}
|
|
}
|