emacs-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Emacs-diffs] /srv/bzr/emacs/trunk r104414: New major mode: Occur Edit m


From: Chong Yidong
Subject: [Emacs-diffs] /srv/bzr/emacs/trunk r104414: New major mode: Occur Edit mode.
Date: Sat, 28 May 2011 18:56:14 -0400
User-agent: Bazaar (2.3.1)

------------------------------------------------------------
revno: 104414
author: Leo Liu <address@hidden>
committer: Chong Yidong <address@hidden>
branch nick: trunk
timestamp: Sat 2011-05-28 18:56:14 -0400
message:
  New major mode: Occur Edit mode.
  
  * lisp/replace.el (occur-menu-map, occur-edit-mode-map): New vars.
  (occur-mode-map): Bind occur-edit-mode.  Use occur-menu-map.
  (occur-edit-mode): New major mode (Bug#8463).
  (occur-after-change-function): New function.
  (occur-engine): Give Occur tags a read-only property.
modified:
  etc/NEWS
  lisp/ChangeLog
  lisp/replace.el
=== modified file 'etc/NEWS'
--- a/etc/NEWS  2011-05-27 01:00:53 +0000
+++ b/etc/NEWS  2011-05-28 22:56:14 +0000
@@ -747,6 +747,9 @@
 
 * New Modes and Packages in Emacs 24.1
 
+** Occur Edit mode applies edits made in *Occur* buffers to the
+original buffers.  It is bound to C-x C-q in Occur mode.
+
 ** New global minor modes electric-pair-mode, electric-indent-mode,
 and electric-layout-mode.
 

=== modified file 'lisp/ChangeLog'
--- a/lisp/ChangeLog    2011-05-28 20:08:05 +0000
+++ b/lisp/ChangeLog    2011-05-28 22:56:14 +0000
@@ -1,3 +1,11 @@
+2011-05-28  Leo Liu  <address@hidden>
+
+       * replace.el (occur-menu-map, occur-edit-mode-map): New vars.
+       (occur-mode-map): Bind occur-edit-mode.  Use occur-menu-map.
+       (occur-edit-mode): New major mode (Bug#8463).
+       (occur-after-change-function): New function.
+       (occur-engine): Give Occur tags a read-only property.
+
 2011-05-28  Kevin Ryde  <address@hidden>
 
        * subr.el (def-edebug-spec): Doc fix (Bug#8430).

=== modified file 'lisp/replace.el'
--- a/lisp/replace.el   2011-04-19 13:44:55 +0000
+++ b/lisp/replace.el   2011-05-28 22:56:14 +0000
@@ -761,22 +761,8 @@
       count)))
 
 
-(defvar occur-mode-map
+(defvar occur-menu-map
   (let ((map (make-sparse-keymap)))
-    ;; We use this alternative name, so we can use \\[occur-mode-mouse-goto].
-    (define-key map [mouse-2] 'occur-mode-mouse-goto)
-    (define-key map "\C-c\C-c" 'occur-mode-goto-occurrence)
-    (define-key map "\C-m" 'occur-mode-goto-occurrence)
-    (define-key map "o" 'occur-mode-goto-occurrence-other-window)
-    (define-key map "\C-o" 'occur-mode-display-occurrence)
-    (define-key map "\M-n" 'occur-next)
-    (define-key map "\M-p" 'occur-prev)
-    (define-key map "r" 'occur-rename-buffer)
-    (define-key map "c" 'clone-buffer)
-    (define-key map "\C-c\C-f" 'next-error-follow-minor-mode)
-    (define-key map [menu-bar] (make-sparse-keymap))
-    (define-key map [menu-bar occur]
-      (cons (purecopy "Occur") map))
     (define-key map [next-error-follow-minor-mode]
       `(menu-item ,(purecopy "Auto Occurrence Display")
                  next-error-follow-minor-mode
@@ -817,6 +803,24 @@
       `(menu-item ,(purecopy "Move to Previous Match") occur-prev
                  :help ,(purecopy "Move to the Nth (default 1) previous match 
in an Occur mode buffer")))
     map)
+  "Menu keymap for `occur-mode'.")
+
+(defvar occur-mode-map
+  (let ((map (make-sparse-keymap)))
+    ;; We use this alternative name, so we can use \\[occur-mode-mouse-goto].
+    (define-key map [mouse-2] 'occur-mode-mouse-goto)
+    (define-key map "\C-c\C-c" 'occur-mode-goto-occurrence)
+    (define-key map "\C-x\C-q" 'occur-edit-mode)
+    (define-key map "\C-m" 'occur-mode-goto-occurrence)
+    (define-key map "o" 'occur-mode-goto-occurrence-other-window)
+    (define-key map "\C-o" 'occur-mode-display-occurrence)
+    (define-key map "\M-n" 'occur-next)
+    (define-key map "\M-p" 'occur-prev)
+    (define-key map "r" 'occur-rename-buffer)
+    (define-key map "c" 'clone-buffer)
+    (define-key map "\C-c\C-f" 'next-error-follow-minor-mode)
+    (define-key map [menu-bar occur] (cons (purecopy "Occur") occur-menu-map))
+    map)
   "Keymap for `occur-mode'.")
 
 (defvar occur-revert-arguments nil
@@ -853,6 +857,63 @@
   (add-hook 'change-major-mode-hook 'font-lock-defontify nil t)
   (setq next-error-function 'occur-next-error))
 
+
+;;; Occur Edit mode
+
+(defvar occur-edit-mode-map
+  (let ((map (make-sparse-keymap)))
+    (set-keymap-parent map text-mode-map)
+    (define-key map [mouse-2] 'occur-mode-mouse-goto)
+    (define-key map "\C-c\C-c" 'occur-mode-goto-occurrence)
+    (define-key map "\C-x\C-q" 'occur-mode)
+    (define-key map "\C-c\C-f" 'next-error-follow-minor-mode)
+    (define-key map [menu-bar occur] (cons (purecopy "Occur") occur-menu-map))
+    map)
+  "Keymap for `occur-edit-mode'.")
+
+(define-derived-mode occur-edit-mode occur-mode "Occur-Edit"
+  "Major mode for editing *Occur* buffers.
+In this mode, changes to the *Occur* buffer are also applied to
+the originating buffer.
+
+To return to ordinary Occur mode, use \\[occur-mode]."
+  (setq buffer-read-only nil)
+  (add-hook 'after-change-functions 'occur-after-change-function nil t))
+
+(defun occur-after-change-function (beg end length)
+  (save-excursion
+    (goto-char beg)
+    (let* ((m (get-text-property (line-beginning-position) 'occur-target))
+          (buf (marker-buffer m))
+          (col (current-column)))
+      (when (= length 0)
+       ;; Apply occur-target property to inserted (e.g. yanked) text.
+       (put-text-property beg end 'occur-target m)
+       ;; Did we insert a newline?  Occur Edit mode can't create new
+       ;; Occur entries; just discard everything after the newline.
+       (save-excursion
+         (and (search-forward "\n" end t)
+              (delete-region (1- (point)) end))))
+      (let ((line (- (line-number-at-pos)
+                    (line-number-at-pos (window-start))))
+           (readonly (with-current-buffer buf buffer-read-only))
+           (win (or (get-buffer-window buf)
+                    (display-buffer buf t)))
+           (text (save-excursion
+                   (forward-line 0)
+                   (search-forward ":" nil t)
+                   (setq col (- col (current-column)))
+                   (buffer-substring-no-properties (point) 
(line-end-position)))))
+       (with-selected-window win
+         (goto-char m)
+         (recenter line)
+         (if readonly
+             (message "Buffer `%s' is read only." buf)
+           (delete-region (line-beginning-position) (line-end-position))
+           (insert text))
+         (move-to-column col))))))
+
+
 (defun occur-revert-function (_ignore1 _ignore2)
   "Handle `revert-buffer' for Occur mode buffers."
   (apply 'occur-1 (append occur-revert-arguments (list (buffer-name)))))
@@ -1280,6 +1341,7 @@
                                      `(font-lock-face prefix-face))
                                    `(occur-prefix t mouse-face (highlight)
                                                   occur-target ,marker 
follow-link t
+                                                  read-only t
                                                   help-echo "mouse-2: go to 
this occurrence"))))
                           (match-str
                            ;; We don't put `mouse-face' on the newline,
@@ -1339,13 +1401,15 @@
                (goto-char headerpt)
                (let ((beg (point))
                      end)
-                 (insert (format "%d match%s%s in buffer: %s\n"
-                                 matches (if (= matches 1) "" "es")
-                                 ;; Don't display regexp for multi-buffer.
-                                 (if (> (length buffers) 1)
-                                     "" (format " for \"%s\""
-                                                (query-replace-descr regexp)))
-                                 (buffer-name buf)))
+                 (insert (propertize
+                          (format "%d match%s%s in buffer: %s\n"
+                                  matches (if (= matches 1) "" "es")
+                                  ;; Don't display regexp for multi-buffer.
+                                  (if (> (length buffers) 1)
+                                      "" (format " for \"%s\""
+                                                 (query-replace-descr regexp)))
+                                  (buffer-name buf))
+                          'read-only t))
                  (setq end (point))
                  (add-text-properties beg end
                                       (append


reply via email to

[Prev in Thread] Current Thread [Next in Thread]