]> git.eshelyaron.com Git - emacs.git/commitdiff
New user variable `exchange-point-and-mark-highlight-region`
authorThierry Volpiatto <thievol@posteo.net>
Sun, 9 Mar 2025 15:08:41 +0000 (16:08 +0100)
committerEshel Yaron <me@eshelyaron.com>
Wed, 12 Mar 2025 19:00:05 +0000 (20:00 +0100)
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

index 7ecb0f708592a126431fb70ca089d36fefe28c40..5e9fedb6e16a0014b8a6d202e0ebdea9d8bb05fc 100644 (file)
@@ -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