From 8bbabdf5a1804cc18b698c2082fd47dd6c3fc299 Mon Sep 17 00:00:00 2001 From: Thierry Volpiatto Date: Sun, 9 Mar 2025 16:08:41 +0100 Subject: [PATCH] New user variable `exchange-point-and-mark-highlight-region` When set to nil, this modifies `exchange-point-and-mark' so that it doesn't activate mark when it is not already active. * etc/NEWS: Introduce new variable exchange-point-and-mark-highlight-region. * lisp/simple.el (exchange-point-and-mark-highlight-region): New. (exchange-point-and-mark): Use it. (cherry picked from commit ef79c8cf3d63f510107536901925c05e37740275) --- lisp/simple.el | 23 ++++++++++++++++++----- 1 file changed, 18 insertions(+), 5 deletions(-) diff --git a/lisp/simple.el b/lisp/simple.el index 7ecb0f70859..5e9fedb6e16 100644 --- a/lisp/simple.el +++ b/lisp/simple.el @@ -7282,10 +7282,20 @@ Does not set point. Does nothing if mark ring is empty." (pop mark-ring)) (deactivate-mark)) +(defcustom exchange-point-and-mark-highlight-region t + "Activate region when exchanging point and mark. + +When set to nil, this modifies `exchange-point-and-mark' so that it doesn't +activate mark when it is not already active." + :type 'boolean + :group 'editing-basics + :version 31.1) + (defun exchange-point-and-mark (&optional arg) "Put the mark where point is now, and point where the mark is now. This command works even when the mark is not active, -and it reactivates the mark. +and it reactivates the mark unless +`exchange-point-and-mark-highlight-region' is nil. If Transient Mark mode is on, a prefix ARG deactivates the mark if it is active, and otherwise avoids reactivating it. If @@ -7293,15 +7303,18 @@ Transient Mark mode is off, a prefix ARG enables Transient Mark mode temporarily." (interactive "P") (let ((omark (mark t)) + (region-was-active (region-active-p)) (temp-highlight (eq (car-safe transient-mark-mode) 'only))) (if (null omark) (user-error "No mark set in this buffer")) (set-mark (point)) (goto-char omark) - (or temp-highlight - (cond ((xor arg (not (region-active-p))) - (deactivate-mark)) - (t (activate-mark)))) + (cond (temp-highlight) + ((xor arg (if exchange-point-and-mark-highlight-region + (not (region-active-p)) + (not region-was-active))) + (deactivate-mark)) + (t (activate-mark))) nil)) (defcustom shift-select-mode t -- 2.39.5