cmd_fetch_pack(): respect constness of argv parameter
The old code cast away the constness of the strings passed to the function in argument argv[], which could result in their being modified by filter_refs(). Fix by copying reference names from argv and putting them into our own array (similarly to how refnames passed to stdin were already handled). Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
ff22ff9909
commit
57e6fc6958
@ -898,10 +898,11 @@ static void fetch_pack_setup(void)
|
|||||||
|
|
||||||
int cmd_fetch_pack(int argc, const char **argv, const char *prefix)
|
int cmd_fetch_pack(int argc, const char **argv, const char *prefix)
|
||||||
{
|
{
|
||||||
int i, ret, nr_heads;
|
int i, ret;
|
||||||
struct ref *ref = NULL;
|
struct ref *ref = NULL;
|
||||||
const char *dest = NULL;
|
const char *dest = NULL;
|
||||||
char **heads;
|
int alloc_heads = 0, nr_heads = 0;
|
||||||
|
char **heads = NULL;
|
||||||
int fd[2];
|
int fd[2];
|
||||||
char *pack_lockfile = NULL;
|
char *pack_lockfile = NULL;
|
||||||
char **pack_lockfile_ptr = NULL;
|
char **pack_lockfile_ptr = NULL;
|
||||||
@ -909,7 +910,6 @@ int cmd_fetch_pack(int argc, const char **argv, const char *prefix)
|
|||||||
|
|
||||||
packet_trace_identity("fetch-pack");
|
packet_trace_identity("fetch-pack");
|
||||||
|
|
||||||
heads = NULL;
|
|
||||||
for (i = 1; i < argc && *argv[i] == '-'; i++) {
|
for (i = 1; i < argc && *argv[i] == '-'; i++) {
|
||||||
const char *arg = argv[i];
|
const char *arg = argv[i];
|
||||||
|
|
||||||
@ -975,17 +975,14 @@ int cmd_fetch_pack(int argc, const char **argv, const char *prefix)
|
|||||||
else
|
else
|
||||||
usage(fetch_pack_usage);
|
usage(fetch_pack_usage);
|
||||||
|
|
||||||
heads = (char **)(argv + i);
|
/*
|
||||||
nr_heads = argc - i;
|
* Copy refs from cmdline to growable list, then append any
|
||||||
|
* refs from the standard input:
|
||||||
|
*/
|
||||||
|
ALLOC_GROW(heads, argc - i, alloc_heads);
|
||||||
|
for (; i < argc; i++)
|
||||||
|
heads[nr_heads++] = xstrdup(argv[i]);
|
||||||
if (args.stdin_refs) {
|
if (args.stdin_refs) {
|
||||||
/*
|
|
||||||
* Copy refs from cmdline to new growable list, then
|
|
||||||
* append the refs from the standard input.
|
|
||||||
*/
|
|
||||||
int alloc_heads = nr_heads;
|
|
||||||
int size = nr_heads * sizeof(*heads);
|
|
||||||
heads = memcpy(xmalloc(size), heads, size);
|
|
||||||
if (args.stateless_rpc) {
|
if (args.stateless_rpc) {
|
||||||
/* in stateless RPC mode we use pkt-line to read
|
/* in stateless RPC mode we use pkt-line to read
|
||||||
* from stdin, until we get a flush packet
|
* from stdin, until we get a flush packet
|
||||||
|
Loading…
x
Reference in New Issue
Block a user