Here's another round of my pkt-line fixes. The more I dug, the more
interesting corners I found. :)
There are really several potentially independent topics rolled together
here. There are dependencies between some of them, so I tried to float
the most independent and non-controversial bits to the beginning. We may
want those as a separate topic to merge sooner, and have the rest as a
topic build on top.
Overall, the diffstat shows a reduction in lines (and I even added a few
dozen lines of comments), which is nice. The intent was to fix some bugs
and corner cases, but I found a lot of cleanup opportunities in the
middle.
builtin/archive.c | 17 ++--
builtin/fetch-pack.c | 11 +-
builtin/receive-pack.c | 10 +-
builtin/send-pack.c | 4 +-
builtin/upload-archive.c | 45 +++------
cache.h | 4 +-
connect.c | 13 +--
daemon.c | 4 +-
fetch-pack.c | 18 ++--
http-backend.c | 8 +-
http.c | 1 +
pkt-line.c | 126 ++++++++++-------------
pkt-line.h | 72 +++++++++++++-
remote-curl.c | 188 ++++++++++++++++-------------------
send-pack.c | 22 ++--
sideband.c | 11 +-
sideband.h | 3 -
t/t5503-tagfollow.sh | 38 ++++---
t/t5700-clone-reference.sh | 10 +-
transport.c | 6 +-
upload-pack.c | 40 +++-----
write_or_die.c | 19 ++--
22 files changed, 321 insertions(+), 349 deletions(-)
The patches are:
[01/19]: upload-pack: use get_sha1_hex to parse "shallow" lines
New in this round; fixes a potential interoperability problem.
[02/19]: upload-pack: do not add duplicate objects to shallow list
New. Fixes a potential memory-consumption denial-of-service.
[03/19]: upload-pack: remove packet debugging harness
New. Optional cleanup, but later patches textually depend on it.
[04/19]: fetch-pack: fix out-of-bounds buffer offset in get_ack
New. Fixes a potential interoperability problem.
[05/19]: send-pack: prefer prefixcmp over memcmp in receive_status
New. Optional cleanup.
[06/19]: upload-archive: do not copy repo name
[07/19]: upload-archive: use argv_array to store client arguments
New. Optional cleanup.
[08/19]: write_or_die: raise SIGPIPE when we get EPIPE
[09/19]: pkt-line: move a misplaced comment
[10/19]: pkt-line: drop safe_write function
The latter two were in the last round; but it's 08/19 that makes
doing 10/19 safe. I think it's also a sane thing to be doing in
general for existing callers of write_or_die.
These can really be pulled into a separate topic if we want, as
there isn't even a lot of textual dependency.
[11/19]: pkt-line: provide a generic reading function with options
This is an alternative to the proliferation of different reading
functions that round 2 had. I think it ends up cleaner. It also
addresses Jonathan's function-signature concerns.
[12/19]: pkt-line: teach packet_read_line to chomp newlines
New. A convenience cleanup that drops a lot of lines. Technically
optional, but later patches depend heavily on it (textually, and for
splitting line-readers from binary-readers).
[13/19]: pkt-line: move LARGE_PACKET_MAX definition from sideband
[14/19]: pkt-line: provide a LARGE_PACKET_MAX static buffer
New. Another cleanup that makes packet_read_line callers a bit
simpler, and bumps the packet size limits throughout git, as we
discussed.
[15/19]: pkt-line: share buffer/descriptor reading implementation
[16/19]: teach get_remote_heads to read from a memory buffer
[17/19]: remote-curl: pass buffer straight to get_remote_heads
These are more or less ported from v2's patches 6-8, except that the
earlier pkt-line changes make the first one way more pleasant.
[18/19]: remote-curl: move ref-parsing code up in file
[19/19]: remote-curl: always parse incoming refs
...and the yak is shaved. More or less a straight rebase of their v2
counterparts, and the thing that actually started me on this topic.
I know it's a big series, but I tried hard to break it down into
bite-sized chunks. Thanks for your reviewing patience.
-Peff
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html