# HG changeset patch # User Richard M. Stallman # Date 740341052 0 # Node ID d852157f581a2e5a66cefd8f3e919d4d68477e39 # Parent 8ba66a5642139d2d893821e0808e72fcc7e085f7 (mouse-start-secondary): New function. (mouse-set-secondary, mouse-drag-secondary): New functions. (mouse-kill-secondary, mouse-secondary-save-then-kill): New functions. diff -r 8ba66a564213 -r d852157f581a lisp/mouse.el --- a/lisp/mouse.el Thu Jun 17 07:31:16 1993 +0000 +++ b/lisp/mouse.el Thu Jun 17 18:17:32 1993 +0000 @@ -161,7 +161,7 @@ (push-mark newmark t t) ;; Turn off the old mark when we set up an empty region. (setq deactivate-mark t)))) - + ;; Subroutine: set the mark where CLICK happened, ;; but don't do anything else. (defun mouse-set-mark-fast (click) @@ -252,7 +252,109 @@ (mouse-show-mark) (setq mouse-save-then-kill-posn (list (car kill-ring) (point) click-posn))))) + +(global-set-key [M-mouse-1] 'mouse-start-secondary) +(global-set-key [M-drag-mouse-1] 'mouse-set-secondary) +(global-set-key [M-down-mouse-1] 'mouse-drag-secondary) +(global-set-key [M-mouse-3] 'mouse-secondary-save-then-kill) +(global-set-key [M-mouse-2] 'mouse-kill-secondary) +;; An overlay which records the current secondary selection +;; or else is deleted when there is no secondary selection. +;; May be nil. +(defvar mouse-secondary-overlay nil) + +;; A marker which records the specified first end for a secondary selection. +;; May be nil. +(defvar mouse-secondary-start nil) + +(defun mouse-start-secondary (click) + "Set one end of the secondary selection to the position clicked on. +Use \\[mouse-secondary-save-then-kill] to set the other end +and complete the secondary selection." + (interactive "e") + (let ((posn (event-start click))) + (select-window (posn-window posn)) + ;; Cancel any preexisting secondary selection. + (if mouse-secondary-overlay + (delete-overlay mouse-secondary-overlay)) + (if (numberp (posn-point posn)) + (progn + (or mouse-secondary-start + (setq mouse-secondary-start (make-marker))) + (move-marker mouse-secondary-start (posn-point posn)))))) + +(defun mouse-set-secondary (click) + "Set the secondary selection to the text that the mouse is dragged over. +This must be bound to a mouse drag event." + (interactive "e") + (let ((posn (event-start click)) + beg + (end (event-end click))) + (select-window (posn-window posn)) + (if (numberp (posn-point posn)) + (setq beg (posn-point posn))) + (if mouse-secondary-overlay + (move-overlay mouse-secondary-overlay beg (posn-point end)) + (setq mouse-secondary-overlay (make-overlay beg (posn-point end)))) + (overlay-put mouse-secondary-overlay 'face 'secondary-selection))) + +(defun mouse-drag-secondary (click) + "Set the secondary selection to the text that the mouse is dragged over. +This must be bound to a button-down mouse event." + (interactive "e") + (let ((posn (event-start click))) + (select-window (posn-window posn)) + ;; Set point temporarily, so user sees where it is. + (if (numberp (posn-point posn)) + (goto-char (posn-point posn))))) + +(defun mouse-kill-secondary () + "Kill the text in the secondary selection." + (interactive "*") + (kill-region (overlay-start mouse-secondary-overlay) + (overlay-end mouse-secondary-overlay)) + (delete-overlay mouse-secondary-overlay) + (setq mouse-secondary-overlay nil)) + +(defun mouse-secondary-save-then-kill (click) + "Save text to secondary start point in kill ring; if twice, kill it. +If the text between secondary start point and the mouse is the same as what's +at the front of the kill ring, this deletes the text. +Otherwise, it adds the text to the kill ring, like \\[kill-ring-save], +which prepares for a second click to delete the text." + (interactive "e") + (let ((click-posn (posn-point (event-start click))) + (start (+ 0 mouse-secondary-start)) + ;; Don't let a subsequent kill command append to this one: + ;; prevent setting this-command to kill-region. + (this-command this-command)) + (if (and (eq last-command 'mouse-secondary-save-then-kill) + mouse-save-then-kill-posn + (eq (car mouse-save-then-kill-posn) (car kill-ring)) + (equal (cdr mouse-save-then-kill-posn) + (list start click-posn))) + ;; If this is the second time we've called + ;; mouse-save-then-kill, delete the text from the buffer. + (progn + (let ((buffer-undo-list t)) + (delete-overlay mouse-secondary-overlay) + (delete-region start click-posn)) + ;; Make the undo list by hand so it is shared. + (if (not (eq buffer-undo-list t)) + (setq buffer-undo-list + (cons (cons (car kill-ring) start) + buffer-undo-list)))) + ;; Otherwise, save this region. + (select-window (posn-window (event-start click))) + (kill-ring-save start click-posn) + (if mouse-secondary-overlay + (move-overlay mouse-secondary-overlay start click-posn) + (setq mouse-secondary-overlay (make-overlay start click-posn))) + (overlay-put mouse-secondary-overlay 'face 'secondary-selection) + (setq mouse-save-then-kill-posn + (list (car kill-ring) start click-posn))))) + (defun mouse-buffer-menu (event) "Pop up a menu of buffers for selection with the mouse. This switches buffers in the window that you clicked on,