зеркало из https://github.com/microsoft/git.git
transport: stop needlessly copying bundle header references
Amend the logic added in fddf2ebe38
(transport: teach all vtables to
allow fetch first, 2019-08-21) and save ourselves pointless work in
fetch_refs_from_bundle().
The fetch_refs_from_bundle() caller doesn't care about the "struct
ref *result" return value of get_refs_from_bundle(), and doesn't need
any of the work we were doing in looping over the
"data->header.references" in get_refs_from_bundle().
So this change saves us work, and also fixes a memory leak that we had
when called from fetch_refs_from_bundle(). The other caller of
get_refs_from_bundle() is the "get_refs_list" member we set up for the
"struct transport_vtable bundle_vtable". That caller does care about
the "struct ref *result" return value.
Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Родитель
bf67dd8d9a
Коммит
0f0d118c65
27
transport.c
27
transport.c
|
@ -125,6 +125,21 @@ struct bundle_transport_data {
|
||||||
unsigned get_refs_from_bundle_called : 1;
|
unsigned get_refs_from_bundle_called : 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static void get_refs_from_bundle_inner(struct transport *transport)
|
||||||
|
{
|
||||||
|
struct bundle_transport_data *data = transport->data;
|
||||||
|
|
||||||
|
data->get_refs_from_bundle_called = 1;
|
||||||
|
|
||||||
|
if (data->fd > 0)
|
||||||
|
close(data->fd);
|
||||||
|
data->fd = read_bundle_header(transport->url, &data->header);
|
||||||
|
if (data->fd < 0)
|
||||||
|
die(_("could not read bundle '%s'"), transport->url);
|
||||||
|
|
||||||
|
transport->hash_algo = data->header.hash_algo;
|
||||||
|
}
|
||||||
|
|
||||||
static struct ref *get_refs_from_bundle(struct transport *transport,
|
static struct ref *get_refs_from_bundle(struct transport *transport,
|
||||||
int for_push,
|
int for_push,
|
||||||
struct transport_ls_refs_options *transport_options)
|
struct transport_ls_refs_options *transport_options)
|
||||||
|
@ -136,15 +151,7 @@ static struct ref *get_refs_from_bundle(struct transport *transport,
|
||||||
if (for_push)
|
if (for_push)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
data->get_refs_from_bundle_called = 1;
|
get_refs_from_bundle_inner(transport);
|
||||||
|
|
||||||
if (data->fd > 0)
|
|
||||||
close(data->fd);
|
|
||||||
data->fd = read_bundle_header(transport->url, &data->header);
|
|
||||||
if (data->fd < 0)
|
|
||||||
die(_("could not read bundle '%s'"), transport->url);
|
|
||||||
|
|
||||||
transport->hash_algo = data->header.hash_algo;
|
|
||||||
|
|
||||||
for (i = 0; i < data->header.references.nr; i++) {
|
for (i = 0; i < data->header.references.nr; i++) {
|
||||||
struct string_list_item *e = data->header.references.items + i;
|
struct string_list_item *e = data->header.references.items + i;
|
||||||
|
@ -169,7 +176,7 @@ static int fetch_refs_from_bundle(struct transport *transport,
|
||||||
strvec_push(&extra_index_pack_args, "-v");
|
strvec_push(&extra_index_pack_args, "-v");
|
||||||
|
|
||||||
if (!data->get_refs_from_bundle_called)
|
if (!data->get_refs_from_bundle_called)
|
||||||
get_refs_from_bundle(transport, 0, NULL);
|
get_refs_from_bundle_inner(transport);
|
||||||
ret = unbundle(the_repository, &data->header, data->fd,
|
ret = unbundle(the_repository, &data->header, data->fd,
|
||||||
&extra_index_pack_args);
|
&extra_index_pack_args);
|
||||||
transport->hash_algo = data->header.hash_algo;
|
transport->hash_algo = data->header.hash_algo;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче