Skip to content

Commit 342c513

Browse files
committed
argv-array: return the pushed string from argv_push*()
Such an API change allows us to use an argv_array this way: struct argv_array to_free = ARGV_ARRAY_INIT; const char *msg; if (some condition) { msg = "constant string message"; ... other logic ... } else { msg = argv_array_pushf(&to_free, "format %s", var); } ... use "msg" ... ... do other things ... argv_array_clear(&to_free); Note that argv_array_pushl() and argv_array_pushv() are used to push one or more strings with a single call, so we do not return any one of these strings from these two functions in order to reduce the chance to misuse the API. Signed-off-by: Junio C Hamano <[email protected]> Signed-off-by: Martin Ågren <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 3f1c1c3 commit 342c513

File tree

2 files changed

+6
-4
lines changed

2 files changed

+6
-4
lines changed

argv-array.c

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -21,12 +21,13 @@ static void argv_array_push_nodup(struct argv_array *array, const char *value)
2121
array->argv[array->argc] = NULL;
2222
}
2323

24-
void argv_array_push(struct argv_array *array, const char *value)
24+
const char *argv_array_push(struct argv_array *array, const char *value)
2525
{
2626
argv_array_push_nodup(array, xstrdup(value));
27+
return array->argv[array->argc - 1];
2728
}
2829

29-
void argv_array_pushf(struct argv_array *array, const char *fmt, ...)
30+
const char *argv_array_pushf(struct argv_array *array, const char *fmt, ...)
3031
{
3132
va_list ap;
3233
struct strbuf v = STRBUF_INIT;
@@ -36,6 +37,7 @@ void argv_array_pushf(struct argv_array *array, const char *fmt, ...)
3637
va_end(ap);
3738

3839
argv_array_push_nodup(array, strbuf_detach(&v, NULL));
40+
return array->argv[array->argc - 1];
3941
}
4042

4143
void argv_array_pushl(struct argv_array *array, ...)

argv-array.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -12,9 +12,9 @@ struct argv_array {
1212
#define ARGV_ARRAY_INIT { empty_argv, 0, 0 }
1313

1414
void argv_array_init(struct argv_array *);
15-
void argv_array_push(struct argv_array *, const char *);
15+
const char *argv_array_push(struct argv_array *, const char *);
1616
__attribute__((format (printf,2,3)))
17-
void argv_array_pushf(struct argv_array *, const char *fmt, ...);
17+
const char *argv_array_pushf(struct argv_array *, const char *fmt, ...);
1818
LAST_ARG_MUST_BE_NULL
1919
void argv_array_pushl(struct argv_array *, ...);
2020
void argv_array_pushv(struct argv_array *, const char **);

0 commit comments

Comments
 (0)