Merge branch 'jc/apply-trailing-blank-removal' into maint
"git apply" misbehaved when fixing whitespace breakages by removing excess trailing blank lines. * jc/apply-trailing-blank-removal: apply.c:update_pre_post_images(): the preimage can be truncatedmaint
commit
7842c44ccb
|
@ -2095,7 +2095,7 @@ static void update_pre_post_images(struct image *preimage,
|
||||||
char *buf,
|
char *buf,
|
||||||
size_t len, size_t postlen)
|
size_t len, size_t postlen)
|
||||||
{
|
{
|
||||||
int i, ctx;
|
int i, ctx, reduced;
|
||||||
char *new, *old, *fixed;
|
char *new, *old, *fixed;
|
||||||
struct image fixed_preimage;
|
struct image fixed_preimage;
|
||||||
|
|
||||||
|
@ -2105,8 +2105,10 @@ static void update_pre_post_images(struct image *preimage,
|
||||||
* free "oldlines".
|
* free "oldlines".
|
||||||
*/
|
*/
|
||||||
prepare_image(&fixed_preimage, buf, len, 1);
|
prepare_image(&fixed_preimage, buf, len, 1);
|
||||||
assert(fixed_preimage.nr == preimage->nr);
|
assert(postlen
|
||||||
for (i = 0; i < preimage->nr; i++)
|
? fixed_preimage.nr == preimage->nr
|
||||||
|
: fixed_preimage.nr <= preimage->nr);
|
||||||
|
for (i = 0; i < fixed_preimage.nr; i++)
|
||||||
fixed_preimage.line[i].flag = preimage->line[i].flag;
|
fixed_preimage.line[i].flag = preimage->line[i].flag;
|
||||||
free(preimage->line_allocated);
|
free(preimage->line_allocated);
|
||||||
*preimage = fixed_preimage;
|
*preimage = fixed_preimage;
|
||||||
|
@ -2126,7 +2128,8 @@ static void update_pre_post_images(struct image *preimage,
|
||||||
else
|
else
|
||||||
new = old;
|
new = old;
|
||||||
fixed = preimage->buf;
|
fixed = preimage->buf;
|
||||||
for (i = ctx = 0; i < postimage->nr; i++) {
|
|
||||||
|
for (i = reduced = ctx = 0; i < postimage->nr; i++) {
|
||||||
size_t len = postimage->line[i].len;
|
size_t len = postimage->line[i].len;
|
||||||
if (!(postimage->line[i].flag & LINE_COMMON)) {
|
if (!(postimage->line[i].flag & LINE_COMMON)) {
|
||||||
/* an added line -- no counterparts in preimage */
|
/* an added line -- no counterparts in preimage */
|
||||||
|
@ -2145,8 +2148,15 @@ static void update_pre_post_images(struct image *preimage,
|
||||||
fixed += preimage->line[ctx].len;
|
fixed += preimage->line[ctx].len;
|
||||||
ctx++;
|
ctx++;
|
||||||
}
|
}
|
||||||
if (preimage->nr <= ctx)
|
|
||||||
die(_("oops"));
|
/*
|
||||||
|
* preimage is expected to run out, if the caller
|
||||||
|
* fixed addition of trailing blank lines.
|
||||||
|
*/
|
||||||
|
if (preimage->nr <= ctx) {
|
||||||
|
reduced++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
/* and copy it in, while fixing the line length */
|
/* and copy it in, while fixing the line length */
|
||||||
len = preimage->line[ctx].len;
|
len = preimage->line[ctx].len;
|
||||||
|
@ -2159,6 +2169,7 @@ static void update_pre_post_images(struct image *preimage,
|
||||||
|
|
||||||
/* Fix the length of the whole thing */
|
/* Fix the length of the whole thing */
|
||||||
postimage->len = new - postimage->buf;
|
postimage->len = new - postimage->buf;
|
||||||
|
postimage->nr -= reduced;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int match_fragment(struct image *img,
|
static int match_fragment(struct image *img,
|
||||||
|
|
Loading…
Reference in New Issue