Merge branch 'jv/pkt-line-batch'
Reduce number of write(2) system calls while sending the ref advertisement. * jv/pkt-line-batch: upload-pack: use stdio in send_ref callbacks pkt-line: add stdio packet write functions
This commit is contained in:
@ -1207,7 +1207,7 @@ static int send_ref(const char *refname, const struct object_id *oid,
|
||||
|
||||
format_symref_info(&symref_info, &data->symref);
|
||||
format_session_id(&session_id, data);
|
||||
packet_write_fmt(1, "%s %s%c%s%s%s%s%s%s%s object-format=%s agent=%s\n",
|
||||
packet_fwrite_fmt(stdout, "%s %s%c%s%s%s%s%s%s%s object-format=%s agent=%s\n",
|
||||
oid_to_hex(oid), refname_nons,
|
||||
0, capabilities,
|
||||
(data->allow_uor & ALLOW_TIP_SHA1) ?
|
||||
@ -1223,11 +1223,11 @@ static int send_ref(const char *refname, const struct object_id *oid,
|
||||
strbuf_release(&symref_info);
|
||||
strbuf_release(&session_id);
|
||||
} else {
|
||||
packet_write_fmt(1, "%s %s\n", oid_to_hex(oid), refname_nons);
|
||||
packet_fwrite_fmt(stdout, "%s %s\n", oid_to_hex(oid), refname_nons);
|
||||
}
|
||||
capabilities = NULL;
|
||||
if (!peel_iterated_oid(oid, &peeled))
|
||||
packet_write_fmt(1, "%s %s^{}\n", oid_to_hex(&peeled), refname_nons);
|
||||
packet_fwrite_fmt(stdout, "%s %s^{}\n", oid_to_hex(&peeled), refname_nons);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1348,6 +1348,11 @@ void upload_pack(struct upload_pack_options *options)
|
||||
reset_timeout(data.timeout);
|
||||
head_ref_namespaced(send_ref, &data);
|
||||
for_each_namespaced_ref(send_ref, &data);
|
||||
/*
|
||||
* fflush stdout before calling advertise_shallow_grafts because send_ref
|
||||
* uses stdio.
|
||||
*/
|
||||
fflush_or_die(stdout);
|
||||
advertise_shallow_grafts(1);
|
||||
packet_flush(1);
|
||||
} else {
|
||||
|
||||
Reference in New Issue
Block a user