bug-gnu-emacs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

bug#66113: Apply the entire diff buffer


From: Dmitry Gutov
Subject: bug#66113: Apply the entire diff buffer
Date: Fri, 22 Sep 2023 16:49:29 +0300
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.13.0

On 22/09/2023 09:45, Juri Linkov wrote:
+          (t
+           (dolist (buf buffers)
+             (with-current-buffer buf
+               (display-buffer buf)))
+           (message "%d hunks failed; no buffers saved" failures)))))

What happens next in this case? How do you undo in the buffers that had the
patch hunks already applied?

Manually, like in case of ediff-patch-buffer.

I've never used this, so I don't understand.

Any change you wanted to work on the idea of the "atomic rollback" as well?

This would be an unreliable feature: in case of diff-apply creates a mess,
such automatic undo can create more mess, because there are many different
strategies to undo the mess such as using undo-auto-amalgamate, or
applying the reverse diff partially, doing more damage in case when
buffers were already modified before diff-apply.

How about we save the tips of buffer-undo-list, then in case the buffer needs reverting, basically 'undo' each of the buffers until the saved "tip" is reached? I don't have a quick code anippet, but that seems doable.

But fortunately the need to undo will be extremely rare, because
when patch hunks are already applied, it reports the failure,
but doesn't modify the source buffer.  Therefore there is
nothing to undo!

The problem situations is, of course, when one of the hunks (somewhere in the middle or near the end) fails to apply cleanly or at all.

Another approach would be to first go through the patch and check that all hunks apply without problems, and then, on the second pass, actually apply them.





reply via email to

[Prev in Thread] Current Thread [Next in Thread]