]> git.ipfire.org Git - thirdparty/git.git/commit
http: simplify parsing of remote objects/info/packs
authorJeff King <peff@peff.net>
Fri, 5 Apr 2019 18:12:55 +0000 (14:12 -0400)
committerJunio C Hamano <gitster@pobox.com>
Tue, 16 Apr 2019 07:58:21 +0000 (16:58 +0900)
commitddc56d4710fa004c922349407f3de0c3adf90ac9
tree3dafab2b4228ad4b66ad941c4fd01e8f32305a77
parentfc78915674ff1bca1726348d7c434dfa0048a5d7
http: simplify parsing of remote objects/info/packs

We can use skip_prefix() and parse_oid_hex() to continuously increment
our pointer, rather than dealing with magic numbers. This also fixes a
few small shortcomings:

  - if we see a line with the right prefix, suffix, and length, i.e.
    matching /P pack-.{40}.pack\n/, we'll interpret the middle part as
    hex without checking if it could be parsed. This could lead to us
    looking at uninitialized garbage in the hash array. In practice this
    means we'll just make a garbage request to the server which will
    fail, though it's interesting that a malicious server could convince
    us to leak 40 bytes of uninitialized stack to them.

  - the current code is picky about seeing a newline at the end of file,
    but we can easily be more liberal

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
http.c