Commit c71dff7e by Patrick Steinhardt

index: fix shared prefix computation when writing index entry

When using compressed index entries, each entry's path is preceded by a
varint encoding how long the shared prefix with the previous index entry
actually is. We currently encode a length of `(path_len - same_len)`,
which is doubly wrong. First, `path_len` is already set to `path_len -
same_len` previously. Second, we want to encode the shared prefix rather
than the un-shared suffix length.

Fix this by using `same_len` as the varint value instead.
parent 83e0392c
...@@ -2661,8 +2661,7 @@ static int write_disk_entry(git_filebuf *file, git_index_entry *entry, const cha ...@@ -2661,8 +2661,7 @@ static int write_disk_entry(git_filebuf *file, git_index_entry *entry, const cha
if (last) { if (last) {
path += git_encode_varint((unsigned char *) path, path += git_encode_varint((unsigned char *) path,
disk_size, disk_size, same_len);
path_len - same_len);
} }
memcpy(path, path_start, path_len); memcpy(path, path_start, path_len);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment