From: Glenn Morris Date: Thu, 18 Oct 2007 04:52:15 +0000 (+0000) Subject: Tom Horsley X-Git-Tag: emacs-pretest-23.0.90~10255 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=d4cb4833594d0b11d79bc96842b55666c8733d9e;p=emacs.git Tom Horsley (interprogram-paste-function): Doc fix. (current-kill): Accept list of strings as well as single string from `interprogram-paste-function'. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index c1603b12907..b4d5f159adf 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,9 @@ +2007-10-15 Tom Horsley + + * simple.el (interprogram-paste-function): Doc fix. + (current-kill): Accept list of strings as well + as single string from `interprogram-paste-function'. + 2007-10-18 Glenn Morris * ibuf-ext.el (ibuffer-saved-filter-groups): Doc fix. diff --git a/lisp/simple.el b/lisp/simple.el index 3d5f6bfab10..ebf0a5ff71e 100644 --- a/lisp/simple.el +++ b/lisp/simple.el @@ -2564,6 +2564,11 @@ of the Emacs kill ring should be used. If the function returns a string, then the caller of the function \(usually `current-kill') should put this string in the kill ring as the latest kill. +This function may also return a list of strings if the window +system supports multiple selections. The first string will be +used as the pasted text, but the other will be placed in the +kill ring for easy access via `yank-pop'. + Note that the function should return a string only if a program other than Emacs has provided a string for pasting; if Emacs provided the most recent string, the function should return nil. If it is @@ -2647,11 +2652,11 @@ If `interprogram-cut-function' is set, pass the resulting kill to it." (defun current-kill (n &optional do-not-move) "Rotate the yanking point by N places, and then return that kill. -If N is zero, `interprogram-paste-function' is set, and calling it -returns a string, then that string is added to the front of the -kill ring and returned as the latest kill. -If optional arg DO-NOT-MOVE is non-nil, then don't actually move the -yanking point; just return the Nth kill forward." +If N is zero, `interprogram-paste-function' is set, and calling it returns a +string or list of strings, then that string (or list) is added to the front +of the kill ring and the string (or first string in the list) is returned as +the latest kill. If optional arg DO-NOT-MOVE is non-nil, then don't +actually move the yanking point; just return the Nth kill forward." (let ((interprogram-paste (and (= n 0) interprogram-paste-function (funcall interprogram-paste-function)))) @@ -2661,8 +2666,10 @@ yanking point; just return the Nth kill forward." ;; text to the kill ring, so Emacs doesn't try to own the ;; selection, with identical text. (let ((interprogram-cut-function nil)) - (kill-new interprogram-paste)) - interprogram-paste) + (if (listp interprogram-paste) + (mapc 'kill-new (nreverse interprogram-paste)) + (kill-new interprogram-paste))) + (car kill-ring)) (or kill-ring (error "Kill ring is empty")) (let ((ARGth-kill-element (nthcdr (mod (- n (length kill-ring-yank-pointer))