combine-diff: combine_diff_path.len is not needed anymore

The field was used in order to speed-up name comparison and also to
mark removed paths by setting it to 0.

Because the updated code does significantly less strcmp and also
just removes paths from the list and free right after we know a path
will not be needed, it is not needed anymore.

Signed-off-by: Kirill Smelkov <kirr@mns.spb.ru>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Kirill Smelkov 2014-01-20 20:20:41 +04:00 committed by Junio C Hamano
parent 8518ff8fab
commit af82c7880f
3 changed files with 9 additions and 24 deletions

View File

@ -31,7 +31,6 @@ static struct combine_diff_path *intersect_paths(struct combine_diff_path *curr,
p->path = (char *) &(p->parent[num_parent]); p->path = (char *) &(p->parent[num_parent]);
memcpy(p->path, path, len); memcpy(p->path, path, len);
p->path[len] = 0; p->path[len] = 0;
p->len = len;
p->next = NULL; p->next = NULL;
memset(p->parent, 0, memset(p->parent, 0,
sizeof(p->parent[0]) * num_parent); sizeof(p->parent[0]) * num_parent);
@ -1234,8 +1233,6 @@ void show_combined_diff(struct combine_diff_path *p,
{ {
struct diff_options *opt = &rev->diffopt; struct diff_options *opt = &rev->diffopt;
if (!p->len)
return;
if (opt->output_format & (DIFF_FORMAT_RAW | if (opt->output_format & (DIFF_FORMAT_RAW |
DIFF_FORMAT_NAME | DIFF_FORMAT_NAME |
DIFF_FORMAT_NAME_STATUS)) DIFF_FORMAT_NAME_STATUS))
@ -1299,11 +1296,8 @@ static void handle_combined_callback(struct diff_options *opt,
q.queue = xcalloc(num_paths, sizeof(struct diff_filepair *)); q.queue = xcalloc(num_paths, sizeof(struct diff_filepair *));
q.alloc = num_paths; q.alloc = num_paths;
q.nr = num_paths; q.nr = num_paths;
for (i = 0, p = paths; p; p = p->next) { for (i = 0, p = paths; p; p = p->next)
if (!p->len)
continue;
q.queue[i++] = combined_pair(p, num_parent); q.queue[i++] = combined_pair(p, num_parent);
}
opt->format_callback(&q, opt, opt->format_callback_data); opt->format_callback(&q, opt, opt->format_callback_data);
for (i = 0; i < num_paths; i++) for (i = 0; i < num_paths; i++)
free_combined_pair(q.queue[i]); free_combined_pair(q.queue[i]);
@ -1369,11 +1363,9 @@ void diff_tree_combined(const unsigned char *sha1,
diff_flush(&diffopts); diff_flush(&diffopts);
} }
/* find out surviving paths */ /* find out number of surviving paths */
for (num_paths = 0, p = paths; p; p = p->next) { for (num_paths = 0, p = paths; p; p = p->next)
if (p->len)
num_paths++; num_paths++;
}
/* order paths according to diffcore_order */ /* order paths according to diffcore_order */
if (opt->orderfile && num_paths) { if (opt->orderfile && num_paths) {
@ -1399,10 +1391,8 @@ void diff_tree_combined(const unsigned char *sha1,
if (opt->output_format & (DIFF_FORMAT_RAW | if (opt->output_format & (DIFF_FORMAT_RAW |
DIFF_FORMAT_NAME | DIFF_FORMAT_NAME |
DIFF_FORMAT_NAME_STATUS)) { DIFF_FORMAT_NAME_STATUS)) {
for (p = paths; p; p = p->next) { for (p = paths; p; p = p->next)
if (p->len)
show_raw_diff(p, num_parent, rev); show_raw_diff(p, num_parent, rev);
}
needsep = 1; needsep = 1;
} }
else if (opt->output_format & else if (opt->output_format &
@ -1415,13 +1405,11 @@ void diff_tree_combined(const unsigned char *sha1,
if (needsep) if (needsep)
printf("%s%c", diff_line_prefix(opt), printf("%s%c", diff_line_prefix(opt),
opt->line_termination); opt->line_termination);
for (p = paths; p; p = p->next) { for (p = paths; p; p = p->next)
if (p->len)
show_patch_diff(p, num_parent, dense, show_patch_diff(p, num_parent, dense,
0, rev); 0, rev);
} }
} }
}
/* Clean things up */ /* Clean things up */
while (paths) { while (paths) {

View File

@ -124,7 +124,6 @@ int run_diff_files(struct rev_info *revs, unsigned int option)
dpath->path = (char *) &(dpath->parent[5]); dpath->path = (char *) &(dpath->parent[5]);
dpath->next = NULL; dpath->next = NULL;
dpath->len = path_len;
memcpy(dpath->path, ce->name, path_len); memcpy(dpath->path, ce->name, path_len);
dpath->path[path_len] = '\0'; dpath->path[path_len] = '\0';
hashclr(dpath->sha1); hashclr(dpath->sha1);
@ -326,7 +325,6 @@ static int show_modified(struct rev_info *revs,
p = xmalloc(combine_diff_path_size(2, pathlen)); p = xmalloc(combine_diff_path_size(2, pathlen));
p->path = (char *) &p->parent[2]; p->path = (char *) &p->parent[2];
p->next = NULL; p->next = NULL;
p->len = pathlen;
memcpy(p->path, new->name, pathlen); memcpy(p->path, new->name, pathlen);
p->path[pathlen] = 0; p->path[pathlen] = 0;
p->mode = mode; p->mode = mode;

1
diff.h
View File

@ -198,7 +198,6 @@ extern int diff_root_tree_sha1(const unsigned char *new, const char *base,
struct combine_diff_path { struct combine_diff_path {
struct combine_diff_path *next; struct combine_diff_path *next;
int len;
char *path; char *path;
unsigned int mode; unsigned int mode;
unsigned char sha1[20]; unsigned char sha1[20];