Merge branch 'jk/fetch-no-tail-match-refs'
* jk/fetch-no-tail-match-refs: connect.c: drop path_match function fetch-pack: match refs exactly t5500: give fully-qualified refs to fetch-pack drop "match" parameter from get_remote_heads
This commit is contained in:
commit
b3ae9d8e57
@ -556,11 +556,16 @@ static void filter_refs(struct ref **refs, int nr_match, char **match)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
int order = path_match(ref->name, nr_match, match);
|
int i;
|
||||||
if (order) {
|
for (i = 0; i < nr_match; i++) {
|
||||||
return_refs[order-1] = ref;
|
if (!strcmp(ref->name, match[i])) {
|
||||||
continue; /* we will link it later */
|
match[i][0] = '\0';
|
||||||
|
return_refs[i] = ref;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
if (i < nr_match)
|
||||||
|
continue; /* we will link it later */
|
||||||
}
|
}
|
||||||
free(ref);
|
free(ref);
|
||||||
}
|
}
|
||||||
@ -976,7 +981,7 @@ int cmd_fetch_pack(int argc, const char **argv, const char *prefix)
|
|||||||
args.verbose ? CONNECT_VERBOSE : 0);
|
args.verbose ? CONNECT_VERBOSE : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
get_remote_heads(fd[0], &ref, 0, NULL, 0, NULL);
|
get_remote_heads(fd[0], &ref, 0, NULL);
|
||||||
|
|
||||||
ref = fetch_pack(&args, fd, conn, ref, dest,
|
ref = fetch_pack(&args, fd, conn, ref, dest,
|
||||||
nr_heads, heads, pack_lockfile_ptr);
|
nr_heads, heads, pack_lockfile_ptr);
|
||||||
|
@ -494,8 +494,7 @@ int cmd_send_pack(int argc, const char **argv, const char *prefix)
|
|||||||
|
|
||||||
memset(&extra_have, 0, sizeof(extra_have));
|
memset(&extra_have, 0, sizeof(extra_have));
|
||||||
|
|
||||||
get_remote_heads(fd[0], &remote_refs, 0, NULL, REF_NORMAL,
|
get_remote_heads(fd[0], &remote_refs, REF_NORMAL, &extra_have);
|
||||||
&extra_have);
|
|
||||||
|
|
||||||
transport_verify_remote_names(nr_refspecs, refspecs);
|
transport_verify_remote_names(nr_refspecs, refspecs);
|
||||||
|
|
||||||
|
3
cache.h
3
cache.h
@ -1032,12 +1032,11 @@ extern char *git_getpass(const char *prompt);
|
|||||||
extern struct child_process *git_connect(int fd[2], const char *url, const char *prog, int flags);
|
extern struct child_process *git_connect(int fd[2], const char *url, const char *prog, int flags);
|
||||||
extern int finish_connect(struct child_process *conn);
|
extern int finish_connect(struct child_process *conn);
|
||||||
extern int git_connection_is_socket(struct child_process *conn);
|
extern int git_connection_is_socket(struct child_process *conn);
|
||||||
extern int path_match(const char *path, int nr, char **match);
|
|
||||||
struct extra_have_objects {
|
struct extra_have_objects {
|
||||||
int nr, alloc;
|
int nr, alloc;
|
||||||
unsigned char (*array)[20];
|
unsigned char (*array)[20];
|
||||||
};
|
};
|
||||||
extern struct ref **get_remote_heads(int in, struct ref **list, int nr_match, char **match, unsigned int flags, struct extra_have_objects *);
|
extern struct ref **get_remote_heads(int in, struct ref **list, unsigned int flags, struct extra_have_objects *);
|
||||||
extern int server_supports(const char *feature);
|
extern int server_supports(const char *feature);
|
||||||
|
|
||||||
extern struct packed_git *parse_pack_index(unsigned char *sha1, const char *idx_path);
|
extern struct packed_git *parse_pack_index(unsigned char *sha1, const char *idx_path);
|
||||||
|
24
connect.c
24
connect.c
@ -53,7 +53,6 @@ static void add_extra_have(struct extra_have_objects *extra, unsigned char *sha1
|
|||||||
* Read all the refs from the other end
|
* Read all the refs from the other end
|
||||||
*/
|
*/
|
||||||
struct ref **get_remote_heads(int in, struct ref **list,
|
struct ref **get_remote_heads(int in, struct ref **list,
|
||||||
int nr_match, char **match,
|
|
||||||
unsigned int flags,
|
unsigned int flags,
|
||||||
struct extra_have_objects *extra_have)
|
struct extra_have_objects *extra_have)
|
||||||
{
|
{
|
||||||
@ -92,8 +91,6 @@ struct ref **get_remote_heads(int in, struct ref **list,
|
|||||||
|
|
||||||
if (!check_ref(name, name_len, flags))
|
if (!check_ref(name, name_len, flags))
|
||||||
continue;
|
continue;
|
||||||
if (nr_match && !path_match(name, nr_match, match))
|
|
||||||
continue;
|
|
||||||
ref = alloc_ref(buffer + 41);
|
ref = alloc_ref(buffer + 41);
|
||||||
hashcpy(ref->old_sha1, old_sha1);
|
hashcpy(ref->old_sha1, old_sha1);
|
||||||
*list = ref;
|
*list = ref;
|
||||||
@ -108,27 +105,6 @@ int server_supports(const char *feature)
|
|||||||
strstr(server_capabilities, feature) != NULL;
|
strstr(server_capabilities, feature) != NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
int path_match(const char *path, int nr, char **match)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
int pathlen = strlen(path);
|
|
||||||
|
|
||||||
for (i = 0; i < nr; i++) {
|
|
||||||
char *s = match[i];
|
|
||||||
int len = strlen(s);
|
|
||||||
|
|
||||||
if (!len || len > pathlen)
|
|
||||||
continue;
|
|
||||||
if (memcmp(path + pathlen - len, s, len))
|
|
||||||
continue;
|
|
||||||
if (pathlen > len && path[pathlen - len - 1] != '/')
|
|
||||||
continue;
|
|
||||||
*s = 0;
|
|
||||||
return (i + 1);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
enum protocol {
|
enum protocol {
|
||||||
PROTO_LOCAL = 1,
|
PROTO_LOCAL = 1,
|
||||||
PROTO_SSH,
|
PROTO_SSH,
|
||||||
|
@ -200,7 +200,7 @@ static struct ref *parse_git_refs(struct discovery *heads)
|
|||||||
|
|
||||||
if (start_async(&async))
|
if (start_async(&async))
|
||||||
die("cannot start thread to parse advertised refs");
|
die("cannot start thread to parse advertised refs");
|
||||||
get_remote_heads(async.out, &list, 0, NULL, 0, NULL);
|
get_remote_heads(async.out, &list, 0, NULL);
|
||||||
close(async.out);
|
close(async.out);
|
||||||
if (finish_async(&async))
|
if (finish_async(&async))
|
||||||
die("ref parsing thread failed");
|
die("ref parsing thread failed");
|
||||||
|
@ -97,7 +97,7 @@ test_expect_success 'setup' '
|
|||||||
git symbolic-ref HEAD refs/heads/B
|
git symbolic-ref HEAD refs/heads/B
|
||||||
'
|
'
|
||||||
|
|
||||||
pull_to_client 1st "B A" $((11*3))
|
pull_to_client 1st "refs/heads/B refs/heads/A" $((11*3))
|
||||||
|
|
||||||
test_expect_success 'post 1st pull setup' '
|
test_expect_success 'post 1st pull setup' '
|
||||||
add A11 $A10 &&
|
add A11 $A10 &&
|
||||||
@ -110,9 +110,9 @@ test_expect_success 'post 1st pull setup' '
|
|||||||
done
|
done
|
||||||
'
|
'
|
||||||
|
|
||||||
pull_to_client 2nd "B" $((64*3))
|
pull_to_client 2nd "refs/heads/B" $((64*3))
|
||||||
|
|
||||||
pull_to_client 3rd "A" $((1*3))
|
pull_to_client 3rd "refs/heads/A" $((1*3))
|
||||||
|
|
||||||
test_expect_success 'clone shallow' '
|
test_expect_success 'clone shallow' '
|
||||||
git clone --depth 2 "file://$(pwd)/." shallow
|
git clone --depth 2 "file://$(pwd)/." shallow
|
||||||
|
29
t/t5527-fetch-odd-refs.sh
Executable file
29
t/t5527-fetch-odd-refs.sh
Executable file
@ -0,0 +1,29 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
test_description='test fetching of oddly-named refs'
|
||||||
|
. ./test-lib.sh
|
||||||
|
|
||||||
|
# afterwards we will have:
|
||||||
|
# HEAD - two
|
||||||
|
# refs/for/refs/heads/master - one
|
||||||
|
# refs/heads/master - three
|
||||||
|
test_expect_success 'setup repo with odd suffix ref' '
|
||||||
|
echo content >file &&
|
||||||
|
git add . &&
|
||||||
|
git commit -m one &&
|
||||||
|
git update-ref refs/for/refs/heads/master HEAD &&
|
||||||
|
echo content >>file &&
|
||||||
|
git commit -a -m two &&
|
||||||
|
echo content >>file &&
|
||||||
|
git commit -a -m three &&
|
||||||
|
git checkout HEAD^
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success 'suffix ref is ignored during fetch' '
|
||||||
|
git clone --bare file://"$PWD" suffix &&
|
||||||
|
echo three >expect &&
|
||||||
|
git --git-dir=suffix log -1 --format=%s refs/heads/master >actual &&
|
||||||
|
test_cmp expect actual
|
||||||
|
'
|
||||||
|
|
||||||
|
test_done
|
@ -502,7 +502,7 @@ static struct ref *get_refs_via_connect(struct transport *transport, int for_pus
|
|||||||
struct ref *refs;
|
struct ref *refs;
|
||||||
|
|
||||||
connect_setup(transport, for_push, 0);
|
connect_setup(transport, for_push, 0);
|
||||||
get_remote_heads(data->fd[0], &refs, 0, NULL,
|
get_remote_heads(data->fd[0], &refs,
|
||||||
for_push ? REF_NORMAL : 0, &data->extra_have);
|
for_push ? REF_NORMAL : 0, &data->extra_have);
|
||||||
data->got_remote_heads = 1;
|
data->got_remote_heads = 1;
|
||||||
|
|
||||||
@ -537,7 +537,7 @@ static int fetch_refs_via_pack(struct transport *transport,
|
|||||||
|
|
||||||
if (!data->got_remote_heads) {
|
if (!data->got_remote_heads) {
|
||||||
connect_setup(transport, 0, 0);
|
connect_setup(transport, 0, 0);
|
||||||
get_remote_heads(data->fd[0], &refs_tmp, 0, NULL, 0, NULL);
|
get_remote_heads(data->fd[0], &refs_tmp, 0, NULL);
|
||||||
data->got_remote_heads = 1;
|
data->got_remote_heads = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -772,8 +772,7 @@ static int git_transport_push(struct transport *transport, struct ref *remote_re
|
|||||||
struct ref *tmp_refs;
|
struct ref *tmp_refs;
|
||||||
connect_setup(transport, 1, 0);
|
connect_setup(transport, 1, 0);
|
||||||
|
|
||||||
get_remote_heads(data->fd[0], &tmp_refs, 0, NULL, REF_NORMAL,
|
get_remote_heads(data->fd[0], &tmp_refs, REF_NORMAL, NULL);
|
||||||
NULL);
|
|
||||||
data->got_remote_heads = 1;
|
data->got_remote_heads = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user