diff options
author | Chong Yidong <cyd@stupidchicken.com> | 2011-08-21 13:56:19 -0400 |
---|---|---|
committer | Chong Yidong <cyd@stupidchicken.com> | 2011-08-21 13:56:19 -0400 |
commit | ff98b2dd51e84b812e061859fa8c682d22b2e459 (patch) | |
tree | 5d02aff0715264d93085f7f84f679ed8749864a4 /lisp/term.el | |
parent | 23a8a5ab697f3389ea6478cdfefe4e67fff28051 (diff) | |
download | emacs-ff98b2dd51e84b812e061859fa8c682d22b2e459.tar.gz |
* lisp/term.el (term-mouse-paste): Yank primary selection (Bug#6845).
Diffstat (limited to 'lisp/term.el')
-rw-r--r-- | lisp/term.el | 21 |
1 files changed, 14 insertions, 7 deletions
diff --git a/lisp/term.el b/lisp/term.el index 6d7f6f5c535..361ff685396 100644 --- a/lisp/term.el +++ b/lisp/term.el @@ -1227,9 +1227,9 @@ without any interpretation." (make-string 1 char) (format "\e%c" char))))) -(defun term-mouse-paste (click arg) - "Insert the last stretch of killed text at the position clicked on." - (interactive "e\nP") +(defun term-mouse-paste (click) + "Insert the primary selection at the position clicked on." + (interactive "e") (if (featurep 'xemacs) (term-send-raw-string (or (condition-case () (x-get-selection) (error ())) @@ -1238,10 +1238,17 @@ without any interpretation." (run-hooks 'mouse-leave-buffer-hook) (setq this-command 'yank) (mouse-set-point click) - (term-send-raw-string (current-kill (cond - ((listp arg) 0) - ((eq arg '-) -1) - (t (1- arg))))))) + (term-send-raw-string + (or (cond ; From `mouse-yank-primary': + ((eq system-type 'windows-nt) + (or (x-get-selection 'PRIMARY) + (x-get-selection-value))) + ((fboundp 'x-get-selection-value) + (or (x-get-selection-value) + (x-get-selection 'PRIMARY))) + (t + (x-get-selection 'PRIMARY))) + (error "No selection is available"))))) (defun term-paste () "Insert the last stretch of killed text at point." |