GNU bug report logs -
#35177
27.0.50; Binding deactivate-mark to nil unexpectedly deactivates the mark
Previous Next
Full log
View this message in rfc822 format
Noam Postavsky <npostavs <at> gmail.com> writes:
> I think the key detail is whether deactivate-mark has a buffer-local
> value or not (modifying the buffer gives it one). If it does have a
> buffer-local value, then the let-binding affects just the buffer-local
> one, otherwise, it binds the global value. So C-x C-e on the following
> always gives an active mark:
Thank you very much for looking into this!
I have constructed an additional test case, which in a sense complements
the previous one in that the mark is now active on the first run, but
inactive in subsequent runs. To reproduce it, please do the following:
1. Download mark_test_run.el with:
$ wget https://www.metalevel.at/ei/mark_test_run.el
2. Invoke Emacs with:
$ emacs -Q mark_test_run.el
3. In that Emacs instance, please do:
M-x evaluate-buffer RET M-x mark-test-run RET
After this, "hello" is displayed and the mark is active.
4. Kill the current buffer (i.e., "b") with C-x k RET
5. Invoke mark-test-run again with M-x mark-test-run RET
After this, "hello" is displayed and the mark is *inactive*.
On subsequent invocations of mark-test-run, the mark is likewise
inactive. However, I expect the mark to be active in all runs, due to
the structure of mark-test-run, which binds deactivate-mark to nil:
(defun mark-test-run ()
(interactive)
(let (deactivate-mark)
...))
Can you reproduce this?
This seems related to the current issue. However, if you consider this
unrelated, please let me know, and I will file this as a separate issue.
For completeness, I include the content of mark_test_run.el below.
All the best,
Markus
(defvar mark-test-forms
'((new-buffer "b")
(insert "hello")
(set-mark-command)
(move-beginning-of-line)))
(defun mark-test-run ()
(interactive)
(let (deactivate-mark)
(mapc 'mark-test-interpret mark-test-forms)))
(defun mark-test-interpret (expr)
(interactive)
(let ((e (car expr)))
(cond ((eq e 'insert)
(insert (cadr expr)))
((eq e 'move-beginning-of-line)
(move-beginning-of-line nil))
((eq e 'new-buffer)
(let ((buf (get-buffer-create (cadr expr))))
(with-current-buffer buf
(erase-buffer))
(switch-to-buffer buf)))
((eq e 'set-mark-command)
(let ((inhibit-message t))
(set-mark-command nil))))))
This bug report was last modified 6 years and 164 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.