apply: fix infinite loop with multiple patches with --index
When multiple patches are passed to git-apply, it will attempt to open multiple file descriptors to an index, which means multiple entries will be in the circular cache_file_list. This change makes git-apply only open the index once and write the index at exit. Signed-off-by: Eric Wong <normalperson@yhbt.net> Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
parent
31fff305bc
commit
dbd0f7d322
18
apply.c
18
apply.c
@ -19,6 +19,7 @@
|
|||||||
//
|
//
|
||||||
static const char *prefix;
|
static const char *prefix;
|
||||||
static int prefix_length = -1;
|
static int prefix_length = -1;
|
||||||
|
static int newfd = -1;
|
||||||
|
|
||||||
static int p_value = 1;
|
static int p_value = 1;
|
||||||
static int allow_binary_replacement = 0;
|
static int allow_binary_replacement = 0;
|
||||||
@ -1873,7 +1874,6 @@ static int use_patch(struct patch *p)
|
|||||||
|
|
||||||
static int apply_patch(int fd, const char *filename)
|
static int apply_patch(int fd, const char *filename)
|
||||||
{
|
{
|
||||||
int newfd;
|
|
||||||
unsigned long offset, size;
|
unsigned long offset, size;
|
||||||
char *buffer = read_patch_file(fd, &size);
|
char *buffer = read_patch_file(fd, &size);
|
||||||
struct patch *list = NULL, **listp = &list;
|
struct patch *list = NULL, **listp = &list;
|
||||||
@ -1904,12 +1904,11 @@ static int apply_patch(int fd, const char *filename)
|
|||||||
size -= nr;
|
size -= nr;
|
||||||
}
|
}
|
||||||
|
|
||||||
newfd = -1;
|
|
||||||
if (whitespace_error && (new_whitespace == error_on_whitespace))
|
if (whitespace_error && (new_whitespace == error_on_whitespace))
|
||||||
apply = 0;
|
apply = 0;
|
||||||
|
|
||||||
write_index = check_index && apply;
|
write_index = check_index && apply;
|
||||||
if (write_index)
|
if (write_index && newfd < 0)
|
||||||
newfd = hold_index_file_for_update(&cache_file, get_index_file());
|
newfd = hold_index_file_for_update(&cache_file, get_index_file());
|
||||||
if (check_index) {
|
if (check_index) {
|
||||||
if (read_cache() < 0)
|
if (read_cache() < 0)
|
||||||
@ -1922,12 +1921,6 @@ static int apply_patch(int fd, const char *filename)
|
|||||||
if (apply)
|
if (apply)
|
||||||
write_out_results(list, skipped_patch);
|
write_out_results(list, skipped_patch);
|
||||||
|
|
||||||
if (write_index) {
|
|
||||||
if (write_cache(newfd, active_cache, active_nr) ||
|
|
||||||
commit_index_file(&cache_file))
|
|
||||||
die("Unable to write new cachefile");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (show_index_info)
|
if (show_index_info)
|
||||||
show_index_list(list);
|
show_index_list(list);
|
||||||
|
|
||||||
@ -2085,5 +2078,12 @@ int main(int argc, char **argv)
|
|||||||
whitespace_error == 1 ? "" : "s",
|
whitespace_error == 1 ? "" : "s",
|
||||||
whitespace_error == 1 ? "s" : "");
|
whitespace_error == 1 ? "s" : "");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (write_index) {
|
||||||
|
if (write_cache(newfd, active_cache, active_nr) ||
|
||||||
|
commit_index_file(&cache_file))
|
||||||
|
die("Unable to write new cachefile");
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user