mirror of
https://github.com/git/git.git
synced 2024-11-24 10:26:17 +08:00
xdiff: handle allocation failure in patience diff
Other users of libxdiff such as libgit2 need to be able to handle allocation failures. As NULL is a valid return value the function signature is changed to be able report allocation failures. Signed-off-by: Phillip Wood <phillip.wood@dunelm.org.uk> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
9df0fc3d57
commit
61f883965f
@ -198,7 +198,7 @@ static int binary_search(struct entry **sequence, int longest,
|
||||
* item per sequence length: the sequence with the smallest last
|
||||
* element (in terms of line2).
|
||||
*/
|
||||
static struct entry *find_longest_common_sequence(struct hashmap *map)
|
||||
static int find_longest_common_sequence(struct hashmap *map, struct entry **res)
|
||||
{
|
||||
struct entry **sequence = xdl_malloc(map->nr * sizeof(struct entry *));
|
||||
int longest = 0, i;
|
||||
@ -211,6 +211,9 @@ static struct entry *find_longest_common_sequence(struct hashmap *map)
|
||||
*/
|
||||
int anchor_i = -1;
|
||||
|
||||
if (!sequence)
|
||||
return -1;
|
||||
|
||||
for (entry = map->first; entry; entry = entry->next) {
|
||||
if (!entry->line2 || entry->line2 == NON_UNIQUE)
|
||||
continue;
|
||||
@ -230,8 +233,9 @@ static struct entry *find_longest_common_sequence(struct hashmap *map)
|
||||
|
||||
/* No common unique lines were found */
|
||||
if (!longest) {
|
||||
*res = NULL;
|
||||
xdl_free(sequence);
|
||||
return NULL;
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Iterate starting at the last element, adjusting the "next" members */
|
||||
@ -241,8 +245,9 @@ static struct entry *find_longest_common_sequence(struct hashmap *map)
|
||||
entry->previous->next = entry;
|
||||
entry = entry->previous;
|
||||
}
|
||||
*res = entry;
|
||||
xdl_free(sequence);
|
||||
return entry;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int match(struct hashmap *map, int line1, int line2)
|
||||
@ -358,14 +363,16 @@ static int patience_diff(mmfile_t *file1, mmfile_t *file2,
|
||||
return 0;
|
||||
}
|
||||
|
||||
first = find_longest_common_sequence(&map);
|
||||
result = find_longest_common_sequence(&map, &first);
|
||||
if (result)
|
||||
goto out;
|
||||
if (first)
|
||||
result = walk_common_sequence(&map, first,
|
||||
line1, count1, line2, count2);
|
||||
else
|
||||
result = fall_back_to_classic_diff(&map,
|
||||
line1, count1, line2, count2);
|
||||
|
||||
out:
|
||||
xdl_free(map.entries);
|
||||
return result;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user