From: Kim F. Storm Date: Tue, 5 Dec 2006 22:35:30 +0000 (+0000) Subject: (cua-paste-pop-rotate-temporarily): Doc fix. X-Git-Tag: emacs-pretest-22.0.92~269 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=fc36357836a4151a1d1b46b2ad466d417f29980d;p=emacs.git (cua-paste-pop-rotate-temporarily): Doc fix. (cua-paste-pop): Rework last change for cua-paste-pop-rotate-temporarily, so first M-y and C-y works alike, pasting the head of the kill-ring, and prefix arg C-u M-y inserts the text inserted by the last M-y command. --- diff --git a/lisp/emulation/cua-base.el b/lisp/emulation/cua-base.el index 6eabed45d4e..d90d01c7879 100644 --- a/lisp/emulation/cua-base.el +++ b/lisp/emulation/cua-base.el @@ -368,11 +368,11 @@ managers, so try setting this to nil, if prefix override doesn't work." (defcustom cua-paste-pop-rotate-temporarily nil "*If non-nil, \\[cua-paste-pop] only rotates the kill-ring temporarily. -This means that \\[cua-paste] always inserts the most recent kill, while one or -more \\[cua-paste-pop]'s immediately following it will replace the previous text -with the next older element on the `kill-ring'. If \\[cua-paste-pop] is used after -any other command, it will insert the same element from the `kill-ring' as last -time it was used." +This means that both \\[yank] and the first \\[yank-pop] in a sequence always insert +the most recently killed text. Each immediately following \\[cua-paste-pop] replaces +the previous text with the next older element on the `kill-ring'. +With prefix arg, \\[universal-argument] \\[yank-pop] inserts the same text as the most +recent \\[yank-pop] (or \\[yank]) command." :type 'boolean :group 'cua) @@ -935,9 +935,11 @@ If global mark is active, copy from register or one character." ;; C-y M-y M-y => only rotates kill ring temporarily, ;; so next C-y yanks what previous C-y yanked, ;; -;; But: After another command, M-y remembers the temporary +;; M-y M-y M-y => equivalent to C-y M-y M-y +;; +;; But: After another command, C-u M-y remembers the temporary ;; kill-ring position, so -;; M-y => yanks what the last M-y yanked +;; C-u M-y => yanks what the last M-y yanked ;; (defvar cua-paste-pop-count nil) @@ -962,18 +964,17 @@ behaviour, see `cua-paste-pop-rotate-temporarily'." (setq cua-paste-pop-count rotate) (setq last-command 'yank) (yank-pop cua-paste-pop-count)) - ((eq last-command 'cua-paste-pop) - (unless (consp arg) - (setq cua-paste-pop-count (+ cua-paste-pop-count rotate))) + ((and (eq last-command 'cua-paste-pop) (not (consp arg))) + (setq cua-paste-pop-count (+ cua-paste-pop-count rotate)) (setq last-command 'yank) (yank-pop cua-paste-pop-count)) (t - (setq cua-paste-pop-count (+ cua-paste-pop-count rotate -1)) + (setq cua-paste-pop-count + (if (consp arg) (+ cua-paste-pop-count rotate -1) 1)) (yank (1+ cua-paste-pop-count))))) ;; Undo rotating the kill-ring, so next C-y will ;; yank the original head. - (unless (consp arg) - (setq kill-ring-yank-pointer kill-ring)) + (setq kill-ring-yank-pointer kill-ring) (setq this-command 'cua-paste-pop)))) (defun cua-exchange-point-and-mark (arg)