From: Kim F. Storm Date: Mon, 18 Apr 2005 19:50:07 +0000 (+0000) Subject: (cua--pre-command-handler): Add more X-Git-Tag: ttn-vms-21-2-B4~912 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=1338947ca028dde8f4ee6fb670b96747c406ac82;p=emacs.git (cua--pre-command-handler): Add more elaborate check for shift modifier on non-window systems. --- diff --git a/lisp/emulation/cua-base.el b/lisp/emulation/cua-base.el index 77e8f636931..6aeb4bab5a2 100644 --- a/lisp/emulation/cua-base.el +++ b/lisp/emulation/cua-base.el @@ -1066,10 +1066,20 @@ If ARG is the atom `-', scroll upward by nearly full screen." ;; If rectangle is active, expand rectangle in specified direction and ignore the movement. (if movement (cond - ((memq 'shift (event-modifiers - (aref (if window-system - (this-single-command-raw-keys) - (this-single-command-keys)) 0))) + ((if window-system + (memq 'shift (event-modifiers + (aref (this-single-command-raw-keys) 0))) + (or + (memq 'shift (event-modifiers + (aref (this-single-command-keys) 0))) + ;; See if raw escape sequence maps to a shifted event, e.g. S-up or C-S-home. + (and (boundp 'function-key-map) + function-key-map + (let ((ev (lookup-key function-key-map + (this-single-command-raw-keys)))) + (and (vector ev) + (symbolp (setq ev (aref ev 0))) + (string-match "S-" (symbol-name ev))))))) (unless mark-active (push-mark-command nil t)) (setq cua--last-region-shifted t)