> Jonathan Tan <[email protected]> writes:
>
> > +int recv_sideband(const char *me, int in_stream, int out)
> > +{
> > + char buf[LARGE_PACKET_MAX + 1];
> > + int retval = 0;
> > + int len;
> > +
> > + while (1) {
> > + len = packet_read(in_stream, NULL, NULL, buf, LARGE_PACKET_MAX,
> > 0);
> > + retval = diagnose_sideband(me, buf, len);
>
> This name of the helper does not convey much useful information.
> Let's think about it more later.
OK - after reading the later comments, switched to demultiplex_sideband.
> > + switch (retval) {
> > + case SIDEBAND_PRIMARY:
>
> Dedent; case/default arms align with 's' in switch in our codebase.
Done.
> > + break;
> > + default: /* flush or error */
> > + return retval;
>
> Lack of corresponding comment bothers readers. In all of
> REMOTE_ERROR, PROGRESS and PROTOCOL_ERROR cases, the other helper
> stuffs the message in outbuf in "switch (band) { ... }" and writes
> it out with xwrite(2, outbuf.buf, outbuf.len) [*1*], so I can see
> there is no need for us to write anything out here. Perhaps
>
> case SIDEBAND_FLUSH:
> default: /* errors: message already written */
> return retval;
>
> or something to clarify?
Done.
> > +/*
> > + * Receive multiplexed output stream over git native protocol.
> > + * in_stream is the input stream from the remote, which carries data
> > + * in pkt_line format with band designator. Demultiplex it into out
> > + * and err and return error appropriately. Band #1 carries the
> > + * primary payload. Things coming over band #2 is not necessarily
> > + * error; they are usually informative message on the standard error
> > + * stream, aka "verbose"). A message over band #3 is a signal that
> > + * the remote died unexpectedly. A flush() concludes the stream.
> > + *
> > + * Returns SIDEBAND_FLUSH upon a normal conclusion, and
> > SIDEBAND_PROTOCOL_ERROR
> > + * or SIDEBAND_REMOTE_ERROR if an error occurred.
> > + */
> > +int recv_sideband(const char *me, int in_stream, int out);
>
> This is well described.
Thanks, although the credit should be given to the original author - most of
this was moved.
> > diff --git a/sideband.c b/sideband.c
> > index 368647acf8..842a92e975 100644
> > --- a/sideband.c
> > +++ b/sideband.c
> > ...
> > +int diagnose_sideband(const char *me, char *buf, int len)
> > {
> > + static const char *suffix;
> > struct strbuf outbuf = STRBUF_INIT;
> > int retval = 0;
> > + const char *b, *brk;
> > + int band;
> > +
> > + if (!suffix) {
> > + if (isatty(2) && !is_terminal_dumb())
> > + suffix = ANSI_SUFFIX;
> > + else
> > + suffix = DUMB_SUFFIX;
> > + }
>
> It may be worth considering a further clean-up for the progress
> code, that consumes lines in the "switch(band)" below that are
> disproportionate to what it does in this function by introducing
> another helper function that is called from here. When it happens,
> the above "suffix" thing should move to the helper function, too.
That's reasonable. If it's OK, I would like to limit the scope of this
patch to splitting the existing recv_sideband() into recv_sideband() and
demultiplex_sideband() (the latter is quite close to the old
recv_sideband(), and the diff looks larger only because most of it is a
dedent).
> So, the point of this helper is to inspect a single packet-line data
> and dispatch the payload of the packet based on which band it is
> sent to. Perhaps call it with a name with demultiplex or dispatch
> in it? "diagnose" is a bit unclear in that what trait you are
> diagnosing and for what purpose.
Changed to demultiplex_sideband.
> > +/*
> > + * buf and len should be the result of reading a line from a remote sending
> > + * multiplexed data.
> > + *
> > + * Determines the nature of the result and returns it. If
>
> "the result" may be from the point of view of the implementor or the
> "recv_sideband()" function who called packet_read(), but a casual
> reader would perceive it more natural if you referred it as "a
> packet read from a remote". "Inspect a packet read from the remote
> and returns which sideband it is for", perhaps?
Done.