Mercurial > hg > xemacs-beta
comparison lisp/tl/mu-replace.el @ 4:b82b59fe008d r19-15b3
Import from CVS: tag r19-15b3
author | cvs |
---|---|
date | Mon, 13 Aug 2007 08:46:56 +0200 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
3:30df88044ec6 | 4:b82b59fe008d |
---|---|
1 ;;; | |
2 ;;; mu-replace.el --- a replacing utility for GNU Emacs | |
3 ;;; | |
4 ;;; Copyright (C) 1995,1996 MORIOKA Tomohiko | |
5 ;;; | |
6 ;;; Author: MORIOKA Tomohiko <morioka@jaist.ac.jp> | |
7 ;;; Version: | |
8 ;;; $Id: mu-replace.el,v 1.1.1.1 1996/12/18 03:55:31 steve Exp $ | |
9 ;;; Keywords: replace | |
10 ;;; | |
11 ;;; This file is part of tl (Tiny Library). | |
12 ;;; | |
13 ;;; This program is free software; you can redistribute it and/or | |
14 ;;; modify it under the terms of the GNU General Public License as | |
15 ;;; published by the Free Software Foundation; either version 2, or | |
16 ;;; (at your option) any later version. | |
17 ;;; | |
18 ;;; This program is distributed in the hope that it will be useful, | |
19 ;;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
20 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
21 ;;; General Public License for more details. | |
22 ;;; | |
23 ;;; You should have received a copy of the GNU General Public License | |
24 ;;; along with This program. If not, write to the Free Software | |
25 ;;; Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. | |
26 ;;; | |
27 ;;; Commentary: | |
28 ;;; | |
29 ;;; - How to install. | |
30 ;;; 1. bytecompile this file and copy it to the apropriate directory. | |
31 ;;; 2. put the following lines to your ~/.emacs: | |
32 ;;; (autoload 'edit-replace-region "mu-replace" nil t) | |
33 ;;; - How to use. | |
34 ;;; 1. mark in beginning of region you want to replace. | |
35 ;;; 2. go to end of region you want to replace. | |
36 ;;; 3. type M-x edit-replace-region [CR] | |
37 ;;; then entering to ``edit-replace mode''. | |
38 ;;; 4. edit replacement string. | |
39 ;;; 5. type C-c C-c then specified region will be replaced. | |
40 ;;; | |
41 ;;; Code: | |
42 | |
43 (defvar edit-replace-mode-map nil) | |
44 (if (null edit-replace-mode-map) | |
45 (progn | |
46 (setq edit-replace-mode-map (copy-keymap text-mode-map)) | |
47 (define-key edit-replace-mode-map | |
48 "\C-c\C-c" (function edit-replace-query-replace)) | |
49 )) | |
50 | |
51 (make-variable-buffer-local 'edit-replace-original-buffer) | |
52 (make-variable-buffer-local 'edit-replace-start-point) | |
53 (make-variable-buffer-local 'edit-replace-end-point) | |
54 | |
55 (defvar edit-replace-original-buffer nil) | |
56 (defvar edit-replace-start-point nil) | |
57 (defvar edit-replace-end-point nil) | |
58 | |
59 (defun edit-replace-region (beg end &optional str) | |
60 (interactive "r") | |
61 (let ((the-buf (current-buffer)) | |
62 (buf (get-buffer-create " *edit-replace*"))) | |
63 (pop-to-buffer buf) | |
64 (setq major-mode 'edit-replace) | |
65 (setq mode-name "edit for replace") | |
66 (use-local-map edit-replace-mode-map) | |
67 (setq edit-replace-original-buffer the-buf) | |
68 (setq edit-replace-start-point beg) | |
69 (setq edit-replace-end-point end) | |
70 )) | |
71 | |
72 (defun edit-replace-query-replace () | |
73 (interactive) | |
74 (let ((beg edit-replace-start-point) | |
75 (end edit-replace-end-point) | |
76 str | |
77 (rstr (buffer-string)) | |
78 ) | |
79 (switch-to-buffer edit-replace-original-buffer) | |
80 (setq str (buffer-substring beg end)) | |
81 (goto-char beg) | |
82 (query-replace str rstr) | |
83 )) | |
84 | |
85 ;;; mu-replace.el ends here |