From: Jeff King Date: Sat, 16 Jul 2011 13:03:26 +0000 (+0200) Subject: transport-helper: don't feed bogus refs to export push X-Git-Tag: v1.7.7-rc0~61^2~15 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=3ea7d09461e4e1b95f6a55f04b2eb66d929464bd;p=git.git transport-helper: don't feed bogus refs to export push When we want to push to a remote helper that has the "export" capability, we collect all of the refs we want to push and then feed them to fast-export. However, the list of refs is actually a list of remote refs, not local refs. The mapped local refs are included via the peer_ref pointer. So when we add an argument to our fast-export command line, we must be sure to use the local peer_ref name (and if there is no local name, it is because we are not actually sending that ref, or we may not even have the ref at all). Signed-off-by: Jeff King Signed-off-by: Sverre Rabbelier Signed-off-by: Junio C Hamano --- diff --git a/t/t5800-remote-helpers.sh b/t/t5800-remote-helpers.sh index ca115ccb7..ceb001057 100755 --- a/t/t5800-remote-helpers.sh +++ b/t/t5800-remote-helpers.sh @@ -106,7 +106,7 @@ test_expect_failure 'fetch multiple branches' ' compare_refs server new localclone refs/remotes/origin/new ' -test_expect_failure 'push when remote has extra refs' ' +test_expect_success 'push when remote has extra refs' ' (cd clone && echo content >>file && git commit -a -m six && diff --git a/transport-helper.c b/transport-helper.c index b560b6414..34d18aaed 100644 --- a/transport-helper.c +++ b/transport-helper.c @@ -730,7 +730,8 @@ static int push_refs_with_export(struct transport *transport, } free(private); - string_list_append(&revlist_args, ref->name); + if (ref->peer_ref) + string_list_append(&revlist_args, ref->peer_ref->name); }