[Mew-dist 1194] mew-sort.el ver 0.06 (for imsort)
Takashi P.KATOH
p-katoh at example.com
1997年 7月 4日 (金) 17:30:47 JST
かとぺ@東北大です。
mew-sort.el を imsort に対応させました。
すでに 0.05 のパッチをあてている場合は以下のパッチをあてずに
mew.el を、
-(defvar mew-prog-sortm "sortm")
+(defvar mew-prog-imsort "imsort")
(431 行目くらい) のように変更 (して byte-compile) して下さい。
--
東北大学大学院 情報科学研究科 白鳥研究室 加藤 貴司
p-katoh at example.com / Takashi P.KATOH
http://www.shiratori.riec.tohoku.ac.jp/~p-katoh/MAIL/
-------------- next part --------------
;;; mew-sort.el
;;;
;;; Copyright (C) 1996 and 1997 Takashi P.KATOH
;;;
;;; This emacs lisp library confirms
;;; GNU GENERAL PUBLIC LICENSE Version 2.
;;;
;;; Author: Takashi P.KATOH <p-katoh at example.com>
;;; Kazuhiko Yamamoto <kazu at example.com>
;;; Created: Febraury 6, 1996
;;; Revised: July 4, 1997
;;;
(defconst mew-sort-version "mew-sort.el version 0.06")
(require 'mew)
(defvar mew-summary-sort-fields
'(("date" . t) ("subject") ("from") ("to") ("newsgroups") ("posted" . t))
"*List of fields for `mew-summary-sort'.
Each element is (FIELD-NAME) or (FIELD-NAME . DATE-P).
If DATE-P is non-nil, messages will be sorted by chronological order.")
(defvar mew-summary-sort-last-field "date")
(defun mew-summary-sort-subr (msgs &optional method)
(let* ((folder (buffer-name))
(msgs (if (listp msgs) msgs (list msgs)))
(completion-ignore-case t)
(field
(completing-read
(concat "Sort " method (if method " ") "by?"
(if mew-summary-sort-last-field
(concat " (default " mew-summary-sort-last-field "): ")
": ")) mew-summary-sort-fields)))
(setq field
(downcase
(if (string-equal field "") mew-summary-sort-last-field field))
mew-summary-sort-last-field field)
(if (not (mew-summary-exclusive-p))
(message "Try later")
(mew-mark-clean-up)
(setq mew-summary-buffer-process t)
(message "Sorting %s by %s ... " folder field)
(if (cdr (assoc field mew-summary-sort-fields))
;; datefield
(apply 'call-process mew-prog-imsort nil nil nil
(append
(list (concat "--src=" folder)
(concat "--datefield="
(if (equal field "date") "date:" field)))
msgs))
;; textfield
(apply 'call-process mew-prog-imsort nil nil nil
(append
(list (concat "--src=" folder)
(concat "--textfield=" field))
msgs)))
(message "Sorting %s by %s ... done" folder field)
(setq mew-summary-buffer-process nil)
(let ((buffer-read-only nil)) (erase-buffer));; for update
(mew-summary-scan-body mew-prog-imls
'mew-summary-mode
folder
mew-cs-scan
(mew-input-range folder))
)
))
(defun mew-summary-sort (&optional arg)
(interactive "P")
(if arg
(mew-summary-sort-region (region-beginning) (region-end) "region")
(mew-summary-sort-region (point-min) (point-max))))
(defun mew-summary-sort-region (r1 r2 &optional method)
(interactive "r")
(let (from to msgs)
(save-excursion
(goto-char r1)
(setq from
(or (mew-summary-message-number)
(progn
(re-search-backward mew-summary-message-regex nil t nil)
(mew-summary-message-number))))
(goto-char r2)
(setq to
(or (mew-summary-message-number)
(progn
(re-search-backward mew-summary-message-regex nil t nil)
(mew-summary-message-number))))
(if (< (string-to-int from) (string-to-int to))
(mew-summary-sort-subr (concat from "-" to) method)
(mew-summary-sort-subr (concat to "-" from) method)))))
(defun mew-summary-mark-sort (&optional r1 r2)
(interactive)
(mew-summary-sort-subr
(mew-summary-mark-collect
mew-mark-hop (or r1 (point-min)) (or r2 (point-max)))
"marked messages"))
(provide 'mew-sort)
-------------- next part --------------
diff -ur mew-1.85.orig/mew-summary.el mew-1.85/mew-summary.el
--- mew-1.85.orig/mew-summary.el Tue Jul 1 10:15:52 1997
+++ mew-1.85/mew-summary.el Fri Jul 4 16:32:13 1997
@@ -34,6 +34,7 @@
["Refile" mew-summary-refile (equal major-mode 'mew-summary-mode)]
["Mark mark" mew-summary-mark-mark t]
["Mark hop" mew-summary-mark-hop t]
+ ["Sort marked msgs" mew-summary-mark-sort t]
["Undo" mew-summary-undo t]
["Undo all" mew-summary-undo-all t]
["Execute" mew-summary-exec (equal major-mode 'mew-summary-mode)]
@@ -159,6 +160,7 @@
(define-key mew-summary-mode-map "mr" 'mew-summary-mark-regexp)
(define-key mew-summary-mode-map "ma" 'mew-summary-mark-all)
(define-key mew-summary-mode-map "mu" 'mew-summary-mark-undo-all)
+ (define-key mew-summary-mode-map "mS" 'mew-summary-mark-sort)
(define-key mew-summary-mode-map "\C-c\C-k" 'mew-summary-kill-subprocess)
;;
(if mew-xemacs-p
@@ -283,6 +285,7 @@
m* Change mark \"@\" into mark \"*\".
m@ Change mark \"*\" into mark \"@\".
ms Swap mark \"@\" and \"*\".
+mS Sort messages whose marks are \"*\".
C-cC-s Incremental search forward on the message buffer.
C-cC-r Incremental search backward on the message buffer.
@@ -1502,27 +1505,27 @@
;;; Sorting and Packing
;;;
-(defun mew-summary-sort ()
- (interactive)
- (let ((folder (buffer-name)))
- (if (not (mew-summary-exclusive-p))
- (message "Try later")
- (mew-mark-clean-up)
- (if (not (mew-y-or-n-p "Sort %s ? " folder))
- ()
- (setq mew-summary-buffer-process t)
- (message "Sorting %s ... " folder)
- (call-process mew-prog-sortm nil nil nil folder)
- (message "Sorting %s ... done" folder)
- (setq mew-summary-buffer-process nil)
- (let ((buffer-read-only nil)) (erase-buffer)) ;; for update
- (mew-summary-scan-body mew-prog-imls
- 'mew-summary-mode
- folder
- mew-cs-scan
- (mew-input-range folder))
- ))
- ))
+;(defun mew-summary-sort ()
+; (interactive)
+; (let ((folder (buffer-name)))
+; (if (not (mew-summary-exclusive-p))
+; (message "Try later")
+; (mew-mark-clean-up)
+; (if (not (mew-y-or-n-p "Sort %s ? " folder))
+; ()
+; (setq mew-summary-buffer-process t)
+; (message "Sorting %s ... " folder)
+; (call-process mew-prog-sortm nil nil nil folder)
+; (message "Sorting %s ... done" folder)
+; (setq mew-summary-buffer-process nil)
+; (let ((buffer-read-only nil)) (erase-buffer)) ;; for update
+; (mew-summary-scan-body mew-prog-imls
+; 'mew-summary-mode
+; folder
+; mew-cs-scan
+; (mew-input-range folder))
+; ))
+; ))
(defun mew-summary-pack ()
(interactive)
diff -ur mew-1.85.orig/mew.el mew-1.85/mew.el
--- mew-1.85.orig/mew.el Tue Jul 1 10:27:19 1997
+++ mew-1.85/mew.el Fri Jul 4 16:32:45 1997
@@ -428,7 +428,7 @@
(defvar mew-prog-impack "impack")
(defvar mew-prog-immv "immv")
(defvar mew-prog-imput "imput")
-(defvar mew-prog-sortm "sortm")
+(defvar mew-prog-imsort "imsort")
(defvar mew-prog-imgrep "imgrep")
(defvar mew-prog-mime-encode "mewencode")
(defvar mew-prog-mime-decode "mewdecode")
@@ -950,6 +950,7 @@
(require 'mew-refile)
(require 'mew-ext)
(require 'mew-fib)
+(require 'mew-sort)
;;;
;;; End of Mew
;;;
Mew-dist メーリングリストの案内