diff options
author | Richard M. Stallman <rms@gnu.org> | 2006-09-28 19:06:39 +0000 |
---|---|---|
committer | Richard M. Stallman <rms@gnu.org> | 2006-09-28 19:06:39 +0000 |
commit | 4f0f29aa95ecc423ade2c389e8b9b565845ae03c (patch) | |
tree | 2fd4dfae2869be283765c266f92b08fd63bc55b2 /lisp/subr.el | |
parent | 7ae8428d900662b301d720ee8d3c0d35c4fee077 (diff) | |
download | emacs-4f0f29aa95ecc423ade2c389e8b9b565845ae03c.tar.gz |
(insert-for-yank-1): Handle `font-lock-face' specially.
Diffstat (limited to 'lisp/subr.el')
-rw-r--r-- | lisp/subr.el | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/lisp/subr.el b/lisp/subr.el index 45decd63924..6668f6423d6 100644 --- a/lisp/subr.el +++ b/lisp/subr.el @@ -2167,11 +2167,32 @@ If UNDO is present and non-nil, it is a function that will be called (let* ((handler (and (stringp string) (get-text-property 0 'yank-handler string))) (param (or (nth 1 handler) string)) - (opoint (point))) + (opoint (point)) + end) + (setq yank-undo-function t) (if (nth 0 handler) ;; FUNCTION (funcall (car handler) param) (insert param)) + (setq end (point)) + + ;; What should we do with `font-lock-face' properties? + (if font-lock-defaults + ;; No, just wipe them. + (remove-list-of-text-properties opoint end '(font-lock-face)) + ;; Convert them to `face'. + (save-excursion + (goto-char opoint) + (while (< (point) end) + (let ((face (get-text-property (point) 'font-lock-face)) + run-end) + (setq run-end + (next-single-property-change (point) 'font-lock-face nil end)) + (when face + (remove-text-properties (point) run-end '(font-lock-face nil)) + (put-text-property (point) run-end 'face face)) + (goto-char run-end))))) + (unless (nth 2 handler) ;; NOEXCLUDE (remove-yank-excluded-properties opoint (point))) (if (eq yank-undo-function t) ;; not set by FUNCTION |