зеркало из https://github.com/microsoft/git.git
packfile: compute and use the index CRC offset
Both v2 pack index files and the v3 format specified as part of the NewHash work have similar data starting at the CRC table. Much of the existing code wants to read either this table or the offset entries following it, and in doing so computes the offset each time. In order to share as much code between v2 and v3, compute the offset of the CRC table and store it when the pack is opened. Use this value to compute offsets to not only the CRC table, but to the offset entries beyond it. Signed-off-by: brian m. carlson <sandals@crustytoothpaste.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Родитель
49c9a2ffe5
Коммит
629dffc461
|
@ -1555,13 +1555,9 @@ static void read_v2_anomalous_offsets(struct packed_git *p,
|
||||||
{
|
{
|
||||||
const uint32_t *idx1, *idx2;
|
const uint32_t *idx1, *idx2;
|
||||||
uint32_t i;
|
uint32_t i;
|
||||||
const uint32_t hashwords = the_hash_algo->rawsz / sizeof(uint32_t);
|
|
||||||
|
|
||||||
/* The address of the 4-byte offset table */
|
/* The address of the 4-byte offset table */
|
||||||
idx1 = (((const uint32_t *)p->index_data)
|
idx1 = (((const uint32_t *)((const uint8_t *)p->index_data + p->crc_offset))
|
||||||
+ 2 /* 8-byte header */
|
|
||||||
+ 256 /* fan out */
|
|
||||||
+ hashwords * p->num_objects /* object ID table */
|
|
||||||
+ p->num_objects /* CRC32 table */
|
+ p->num_objects /* CRC32 table */
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -70,6 +70,7 @@ struct packed_git {
|
||||||
size_t index_size;
|
size_t index_size;
|
||||||
uint32_t num_objects;
|
uint32_t num_objects;
|
||||||
uint32_t num_bad_objects;
|
uint32_t num_bad_objects;
|
||||||
|
uint32_t crc_offset;
|
||||||
unsigned char *bad_object_sha1;
|
unsigned char *bad_object_sha1;
|
||||||
int index_version;
|
int index_version;
|
||||||
time_t mtime;
|
time_t mtime;
|
||||||
|
|
|
@ -178,6 +178,7 @@ int load_idx(const char *path, const unsigned int hashsz, void *idx_map,
|
||||||
*/
|
*/
|
||||||
(sizeof(off_t) <= 4))
|
(sizeof(off_t) <= 4))
|
||||||
return error("pack too large for current definition of off_t in %s", path);
|
return error("pack too large for current definition of off_t in %s", path);
|
||||||
|
p->crc_offset = 8 + 4 * 256 + nr * hashsz;
|
||||||
}
|
}
|
||||||
|
|
||||||
p->index_version = version;
|
p->index_version = version;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче