Browse Source

Merge branch 'np/pack'

* np/pack:
  improve depth heuristic for maximum delta size
  pack-object: slightly more efficient
  simple euristic for further free packing improvements
maint
Junio C Hamano 19 years ago
parent
commit
0fa6417c49
  1. 2
      delta.h
  2. 27
      pack-objects.c

2
delta.h

@ -18,6 +18,8 @@ create_delta_index(const void *buf, unsigned long bufsize);


/* /*
* free_delta_index: free the index created by create_delta_index() * free_delta_index: free the index created by create_delta_index()
*
* Given pointer must be what create_delta_index() returned, or NULL.
*/ */
extern void free_delta_index(struct delta_index *index); extern void free_delta_index(struct delta_index *index);



27
pack-objects.c

@ -1036,10 +1036,13 @@ static int try_delta(struct unpacked *trg, struct unpacked *src,
if (src_entry->depth >= max_depth) if (src_entry->depth >= max_depth)
return 0; return 0;


/* Now some size filtering euristics. */ /* Now some size filtering heuristics. */
size = trg_entry->size; size = trg_entry->size;
max_size = size / 2 - 20; max_size = size/2 - 20;
if (trg_entry->delta) max_size = max_size * (max_depth - src_entry->depth) / max_depth;
if (max_size == 0)
return 0;
if (trg_entry->delta && trg_entry->delta_size <= max_size)
max_size = trg_entry->delta_size-1; max_size = trg_entry->delta_size-1;
src_size = src_entry->size; src_size = src_entry->size;
sizediff = src_size < size ? size - src_size : 0; sizediff = src_size < size ? size - src_size : 0;
@ -1104,17 +1107,14 @@ static void find_deltas(struct object_entry **list, int window, int depth)


if (entry->size < 50) if (entry->size < 50)
continue; continue;
if (n->index) free_delta_index(n->index);
free_delta_index(n->index); n->index = NULL;
free(n->data); free(n->data);
n->entry = entry; n->entry = entry;
n->data = read_sha1_file(entry->sha1, type, &size); n->data = read_sha1_file(entry->sha1, type, &size);
if (size != entry->size) if (size != entry->size)
die("object %s inconsistent object length (%lu vs %lu)", die("object %s inconsistent object length (%lu vs %lu)",
sha1_to_hex(entry->sha1), size, entry->size); sha1_to_hex(entry->sha1), size, entry->size);
n->index = create_delta_index(n->data, size);
if (!n->index)
die("out of memory");


j = window; j = window;
while (--j > 0) { while (--j > 0) {
@ -1128,15 +1128,17 @@ static void find_deltas(struct object_entry **list, int window, int depth)
if (try_delta(n, m, m->index, depth) < 0) if (try_delta(n, m, m->index, depth) < 0)
break; break;
} }
#if 0
/* if we made n a delta, and if n is already at max /* if we made n a delta, and if n is already at max
* depth, leaving it in the window is pointless. we * depth, leaving it in the window is pointless. we
* should evict it first. * should evict it first.
* ... in theory only; somehow this makes things worse.
*/ */
if (entry->delta && depth <= entry->depth) if (entry->delta && depth <= entry->depth)
continue; continue;
#endif
n->index = create_delta_index(n->data, size);
if (!n->index)
die("out of memory");

idx++; idx++;
if (idx >= window) if (idx >= window)
idx = 0; idx = 0;
@ -1146,8 +1148,7 @@ static void find_deltas(struct object_entry **list, int window, int depth)
fputc('\n', stderr); fputc('\n', stderr);


for (i = 0; i < window; ++i) { for (i = 0; i < window; ++i) {
if (array[i].index) free_delta_index(array[i].index);
free_delta_index(array[i].index);
free(array[i].data); free(array[i].data);
} }
free(array); free(array);

Loading…
Cancel
Save