Skip to content

Commit ad6ac12

Browse files
bmwillgitster
authored andcommitted
connect: discover protocol version outside of get_remote_heads
In order to prepare for the addition of protocol_v2 push the protocol version discovery outside of 'get_remote_heads()'. This will allow for keeping the logic for processing the reference advertisement for protocol_v1 and protocol_v0 separate from the logic for protocol_v2. Signed-off-by: Brandon Williams <bmwill@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
1 parent 7e3e479 commit ad6ac12

File tree

7 files changed

+83
-29
lines changed

7 files changed

+83
-29
lines changed

builtin/fetch-pack.c

Lines changed: 15 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@
44
#include "remote.h"
55
#include "connect.h"
66
#include "sha1-array.h"
7+
#include "protocol.h"
78

89
static const char fetch_pack_usage[] =
910
"git fetch-pack [--all] [--stdin] [--quiet | -q] [--keep | -k] [--thin] "
@@ -52,6 +53,7 @@ int cmd_fetch_pack(int argc, const char **argv, const char *prefix)
5253
struct fetch_pack_args args;
5354
struct oid_array shallow = OID_ARRAY_INIT;
5455
struct string_list deepen_not = STRING_LIST_INIT_DUP;
56+
struct packet_reader reader;
5557

5658
packet_trace_identity("fetch-pack");
5759

@@ -193,7 +195,19 @@ int cmd_fetch_pack(int argc, const char **argv, const char *prefix)
193195
if (!conn)
194196
return args.diag_url ? 0 : 1;
195197
}
196-
get_remote_heads(fd[0], NULL, 0, &ref, 0, NULL, &shallow);
198+
199+
packet_reader_init(&reader, fd[0], NULL, 0,
200+
PACKET_READ_CHOMP_NEWLINE |
201+
PACKET_READ_GENTLE_ON_EOF);
202+
203+
switch (discover_version(&reader)) {
204+
case protocol_v1:
205+
case protocol_v0:
206+
get_remote_heads(&reader, &ref, 0, NULL, &shallow);
207+
break;
208+
case protocol_unknown_version:
209+
BUG("unknown protocol version");
210+
}
197211

198212
ref = fetch_pack(&args, fd, conn, ref, dest, sought, nr_sought,
199213
&shallow, pack_lockfile_ptr);

builtin/send-pack.c

Lines changed: 15 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,7 @@
1414
#include "sha1-array.h"
1515
#include "gpg-interface.h"
1616
#include "gettext.h"
17+
#include "protocol.h"
1718

1819
static const char * const send_pack_usage[] = {
1920
N_("git send-pack [--all | --mirror] [--dry-run] [--force] "
@@ -154,6 +155,7 @@ int cmd_send_pack(int argc, const char **argv, const char *prefix)
154155
int progress = -1;
155156
int from_stdin = 0;
156157
struct push_cas_option cas = {0};
158+
struct packet_reader reader;
157159

158160
struct option options[] = {
159161
OPT__VERBOSITY(&verbose),
@@ -256,8 +258,19 @@ int cmd_send_pack(int argc, const char **argv, const char *prefix)
256258
args.verbose ? CONNECT_VERBOSE : 0);
257259
}
258260

259-
get_remote_heads(fd[0], NULL, 0, &remote_refs, REF_NORMAL,
260-
&extra_have, &shallow);
261+
packet_reader_init(&reader, fd[0], NULL, 0,
262+
PACKET_READ_CHOMP_NEWLINE |
263+
PACKET_READ_GENTLE_ON_EOF);
264+
265+
switch (discover_version(&reader)) {
266+
case protocol_v1:
267+
case protocol_v0:
268+
get_remote_heads(&reader, &remote_refs, REF_NORMAL,
269+
&extra_have, &shallow);
270+
break;
271+
case protocol_unknown_version:
272+
BUG("unknown protocol version");
273+
}
261274

262275
transport_verify_remote_names(nr_refspecs, refspecs);
263276

connect.c

Lines changed: 10 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -62,7 +62,7 @@ static void die_initial_contact(int unexpected)
6262
"and the repository exists."));
6363
}
6464

65-
static enum protocol_version discover_version(struct packet_reader *reader)
65+
enum protocol_version discover_version(struct packet_reader *reader)
6666
{
6767
enum protocol_version version = protocol_unknown_version;
6868

@@ -233,32 +233,25 @@ enum get_remote_heads_state {
233233
/*
234234
* Read all the refs from the other end
235235
*/
236-
struct ref **get_remote_heads(int in, char *src_buf, size_t src_len,
236+
struct ref **get_remote_heads(struct packet_reader *reader,
237237
struct ref **list, unsigned int flags,
238238
struct oid_array *extra_have,
239239
struct oid_array *shallow_points)
240240
{
241241
struct ref **orig_list = list;
242242
int len = 0;
243243
enum get_remote_heads_state state = EXPECTING_FIRST_REF;
244-
struct packet_reader reader;
245244
const char *arg;
246245

247-
packet_reader_init(&reader, in, src_buf, src_len,
248-
PACKET_READ_CHOMP_NEWLINE |
249-
PACKET_READ_GENTLE_ON_EOF);
250-
251-
discover_version(&reader);
252-
253246
*list = NULL;
254247

255248
while (state != EXPECTING_DONE) {
256-
switch (packet_reader_read(&reader)) {
249+
switch (packet_reader_read(reader)) {
257250
case PACKET_READ_EOF:
258251
die_initial_contact(1);
259252
case PACKET_READ_NORMAL:
260-
len = reader.pktlen;
261-
if (len > 4 && skip_prefix(reader.line, "ERR ", &arg))
253+
len = reader->pktlen;
254+
if (len > 4 && skip_prefix(reader->line, "ERR ", &arg))
262255
die("remote error: %s", arg);
263256
break;
264257
case PACKET_READ_FLUSH:
@@ -270,22 +263,22 @@ struct ref **get_remote_heads(int in, char *src_buf, size_t src_len,
270263

271264
switch (state) {
272265
case EXPECTING_FIRST_REF:
273-
process_capabilities(reader.line, &len);
274-
if (process_dummy_ref(reader.line)) {
266+
process_capabilities(reader->line, &len);
267+
if (process_dummy_ref(reader->line)) {
275268
state = EXPECTING_SHALLOW;
276269
break;
277270
}
278271
state = EXPECTING_REF;
279272
/* fallthrough */
280273
case EXPECTING_REF:
281-
if (process_ref(reader.line, len, &list, flags, extra_have))
274+
if (process_ref(reader->line, len, &list, flags, extra_have))
282275
break;
283276
state = EXPECTING_SHALLOW;
284277
/* fallthrough */
285278
case EXPECTING_SHALLOW:
286-
if (process_shallow(reader.line, len, shallow_points))
279+
if (process_shallow(reader->line, len, shallow_points))
287280
break;
288-
die("protocol error: unexpected '%s'", reader.line);
281+
die("protocol error: unexpected '%s'", reader->line);
289282
case EXPECTING_DONE:
290283
break;
291284
}

connect.h

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -13,4 +13,7 @@ extern int parse_feature_request(const char *features, const char *feature);
1313
extern const char *server_feature_value(const char *feature, int *len_ret);
1414
extern int url_is_local_not_ssh(const char *url);
1515

16+
struct packet_reader;
17+
extern enum protocol_version discover_version(struct packet_reader *reader);
18+
1619
#endif

remote-curl.c

Lines changed: 18 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
#include "cache.h"
22
#include "config.h"
33
#include "remote.h"
4+
#include "connect.h"
45
#include "strbuf.h"
56
#include "walker.h"
67
#include "http.h"
@@ -13,6 +14,7 @@
1314
#include "credential.h"
1415
#include "sha1-array.h"
1516
#include "send-pack.h"
17+
#include "protocol.h"
1618

1719
static struct remote *remote;
1820
/* always ends with a trailing slash */
@@ -176,8 +178,22 @@ static struct discovery *last_discovery;
176178
static struct ref *parse_git_refs(struct discovery *heads, int for_push)
177179
{
178180
struct ref *list = NULL;
179-
get_remote_heads(-1, heads->buf, heads->len, &list,
180-
for_push ? REF_NORMAL : 0, NULL, &heads->shallow);
181+
struct packet_reader reader;
182+
183+
packet_reader_init(&reader, -1, heads->buf, heads->len,
184+
PACKET_READ_CHOMP_NEWLINE |
185+
PACKET_READ_GENTLE_ON_EOF);
186+
187+
switch (discover_version(&reader)) {
188+
case protocol_v1:
189+
case protocol_v0:
190+
get_remote_heads(&reader, &list, for_push ? REF_NORMAL : 0,
191+
NULL, &heads->shallow);
192+
break;
193+
case protocol_unknown_version:
194+
BUG("unknown protocol version");
195+
}
196+
181197
return list;
182198
}
183199

remote.h

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -150,10 +150,11 @@ int check_ref_type(const struct ref *ref, int flags);
150150
void free_refs(struct ref *ref);
151151

152152
struct oid_array;
153-
extern struct ref **get_remote_heads(int in, char *src_buf, size_t src_len,
153+
struct packet_reader;
154+
extern struct ref **get_remote_heads(struct packet_reader *reader,
154155
struct ref **list, unsigned int flags,
155156
struct oid_array *extra_have,
156-
struct oid_array *shallow);
157+
struct oid_array *shallow_points);
157158

158159
int resolve_remote_symref(struct ref *ref, struct ref *list);
159160
int ref_newer(const struct object_id *new_oid, const struct object_id *old_oid);

transport.c

Lines changed: 19 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,7 @@
1818
#include "sha1-array.h"
1919
#include "sigchain.h"
2020
#include "transport-internal.h"
21+
#include "protocol.h"
2122

2223
static void set_upstreams(struct transport *transport, struct ref *refs,
2324
int pretend)
@@ -190,13 +191,26 @@ static int connect_setup(struct transport *transport, int for_push)
190191
static struct ref *get_refs_via_connect(struct transport *transport, int for_push)
191192
{
192193
struct git_transport_data *data = transport->data;
193-
struct ref *refs;
194+
struct ref *refs = NULL;
195+
struct packet_reader reader;
194196

195197
connect_setup(transport, for_push);
196-
get_remote_heads(data->fd[0], NULL, 0, &refs,
197-
for_push ? REF_NORMAL : 0,
198-
&data->extra_have,
199-
&data->shallow);
198+
199+
packet_reader_init(&reader, data->fd[0], NULL, 0,
200+
PACKET_READ_CHOMP_NEWLINE |
201+
PACKET_READ_GENTLE_ON_EOF);
202+
203+
switch (discover_version(&reader)) {
204+
case protocol_v1:
205+
case protocol_v0:
206+
get_remote_heads(&reader, &refs,
207+
for_push ? REF_NORMAL : 0,
208+
&data->extra_have,
209+
&data->shallow);
210+
break;
211+
case protocol_unknown_version:
212+
BUG("unknown protocol version");
213+
}
200214
data->got_remote_heads = 1;
201215

202216
return refs;

0 commit comments

Comments
 (0)