From: Stefan Monnier <monnier@iro.umontreal.ca>
To: phillip.lord@russet.org.uk (Phillip Lord)
Cc: 23871@debbugs.gnu.org, triska@metalevel.at
Subject: bug#23871: 25.1.50; Undo unexpectedly leads to blank buffer
Date: Sun, 03 Jul 2016 17:33:15 -0400 [thread overview]
Message-ID: <jwv37nqa0dc.fsf-monnier+bug#23871@gnu.org> (raw)
In-Reply-To: <87k2h37pvb.fsf@russet.org.uk> (Phillip Lord's message of "Sat, 02 Jul 2016 21:21:28 +0100")
>> From d4e9e44402fdf248ba4bc895e914d4cc5580f229 Mon Sep 17 00:00:00 2001
> From: Phillip Lord <phillip.lord@russet.org.uk>
> Date: Thu, 30 Jun 2016 22:06:00 +0100
> Subject: [PATCH] Fix missing point information in undo
> * src/undo.c (record_insert): Use record_point instead of
> prepare_record, and do so unconditionally.
> (prepare_record): Do not record first change.
> (record_point): Now conditional on state before the last command.
> (record_delete): Call record_point unconditionally.
I haven't had time to look in detail at this patch, so it's hard for me
to give a strong agreement. Maybe some explanations would help.
Could you give a verbosish "commit log" explaining the reason behind
each hunk?
> @@ -40,16 +40,13 @@ prepare_record (void)
> /* Allocate a cons cell to be the undo boundary after this command. */
> if (NILP (pending_boundary))
> pending_boundary = Fcons (Qnil, Qnil);
> -
> - if (MODIFF <= SAVE_MODIFF)
> - record_first_change ();
> }
Not sure why/how this is related to the other changes, nor why this code
was there in the first place.
But in any case, the comment before prepare_record needs to be updated,
because it seems to describe neither the current behavior, nor the
behavior after applying the above hunk.
BTW, I notice that in the current code (emacs-25), there's one other
call to record_first_change (in record_property_change), and it could be
replaced with a call to prepare_record, so it begs the question whether
the above hunk should also apply to record_property_change as well.
> /* Record point as it was at beginning of this command.
> - PT is the position of point that will naturally occur as a result of the
> + BEG is the position of point that will naturally occur as a result of the
> undo record that will be added just after this command terminates. */
> static void
> -record_point (ptrdiff_t pt)
> +record_point (ptrdiff_t beg)
> {
> /* Don't record position of pt when undo_inhibit_record_point holds. */
> if (undo_inhibit_record_point)
> @@ -60,13 +57,16 @@ record_point (ptrdiff_t pt)
> at_boundary = ! CONSP (BVAR (current_buffer, undo_list))
> || NILP (XCAR (BVAR (current_buffer, undo_list)));
You said:
The problem was caused because of undo only records point after a
boundary (or the first element). I'd changed things during slightly when
I update undo.c so that the timestamp list got added before checking
whether I was at a boundary, hence blocking addition of the point
restoration information.
so maybe the computation of at_boundary above should be tweaked to
ignore timestamps?
> /* If we are just after an undo boundary, and
> point wasn't at start of deleted range, record where it was. */
> - if (at_boundary)
> + if (at_boundary
> + && point_before_last_command_or_undo != beg
> + && buffer_before_last_command_or_undo == current_buffer )
> bset_undo_list (current_buffer,
> - Fcons (make_number (pt),
> + Fcons (make_number (point_before_last_command_or_undo),
> BVAR (current_buffer, undo_list)));
I like this part.
> - if (point_before_last_command_or_undo != beg
> - && buffer_before_last_command_or_undo == current_buffer)
> - record_point (point_before_last_command_or_undo);
> + prepare_record ();
> +
> + record_point (beg);
And I like this part too.
Stefan
next prev parent reply other threads:[~2016-07-03 21:33 UTC|newest]
Thread overview: 51+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-06-29 21:47 bug#23871: 25.1.50; Undo unexpectedly leads to blank buffer Markus Triska
2016-06-30 16:38 ` Eli Zaretskii
2016-06-30 18:00 ` Markus Triska
2016-06-30 18:21 ` Eli Zaretskii
2016-06-30 18:52 ` Eli Zaretskii
2016-06-30 21:45 ` Phillip Lord
2016-07-01 6:31 ` Markus Triska
2016-07-01 7:25 ` Eli Zaretskii
2016-07-01 14:04 ` Phillip Lord
2016-07-01 20:38 ` Markus Triska
2016-07-01 22:12 ` Phillip Lord
2016-07-01 20:49 ` Markus Triska
2016-07-01 22:21 ` Phillip Lord
2016-07-02 5:35 ` Markus Triska
2016-07-02 7:35 ` Eli Zaretskii
2016-07-02 20:21 ` Phillip Lord
2016-07-02 20:53 ` Markus Triska
2016-07-03 3:33 ` Eli Zaretskii
2016-07-03 9:37 ` Phillip Lord
2016-07-03 10:08 ` Markus Triska
2016-07-03 12:55 ` Phillip Lord
2016-07-03 15:30 ` Eli Zaretskii
2016-07-03 20:21 ` Phillip Lord
2016-07-03 18:05 ` Markus Triska
2016-07-03 20:23 ` Phillip Lord
2016-07-03 22:03 ` Markus Triska
2016-07-04 14:38 ` Eli Zaretskii
2016-07-05 16:36 ` Eli Zaretskii
2016-07-05 19:44 ` Phillip Lord
2016-07-05 20:02 ` Markus Triska
2016-07-05 19:47 ` Markus Triska
2016-07-05 20:00 ` Eli Zaretskii
2016-07-03 15:12 ` Eli Zaretskii
2016-07-03 18:09 ` Markus Triska
2016-07-03 19:20 ` Eli Zaretskii
2016-07-03 20:37 ` Phillip Lord
2016-07-03 3:31 ` Eli Zaretskii
2016-07-03 9:39 ` Phillip Lord
2016-07-03 21:33 ` Stefan Monnier [this message]
2016-07-04 20:34 ` Phillip Lord
2016-07-04 21:32 ` Stefan Monnier
2016-07-05 8:43 ` Phillip Lord
2016-07-05 20:32 ` Markus Triska
2016-07-05 22:00 ` Stefan Monnier
2016-07-05 22:17 ` Phillip Lord
2016-07-05 22:09 ` Phillip Lord
2016-07-05 23:03 ` Markus Triska
2016-07-06 16:02 ` Phillip Lord
2016-07-06 17:59 ` Markus Triska
2016-08-12 23:03 ` npostavs
2016-08-13 8:02 ` Markus Triska
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='jwv37nqa0dc.fsf-monnier+bug#23871@gnu.org' \
--to=monnier@iro.umontreal.ca \
--cc=23871@debbugs.gnu.org \
--cc=phillip.lord@russet.org.uk \
--cc=triska@metalevel.at \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).