[mew-win32 04137] Re: Firefox -> mozex -> mailto -> Mew

Hideyuki SHIRAI ( 白井秀行 ) shirai at example.com
2004年 11月 8日 (月) 19:15:18 JST


白井です。

# たくさん間が空いてしまってごめんなさい。

From: unisus at example.com さん曰く
Subject: [mew-win32 04136] Re: Firefox -> mozex -> mailto -> Mew
Message-ID: <20041025.225302.126572512.unisus at example.com>
Date: Mon, 25 Oct 2004 22:53:02 +0900 (JST)

> 一応この変更でうまく行きますので、
> 下記の場所に、差分と差分を当てたパッケージを置いておきます。
> 
> http://members.jcom.home.ne.jp/unisus/app/mozex/mozex-1.07-i18n-0.1-0.1.diff
> http://members.jcom.home.ne.jp/unisus/app/mozex/mozex-1.07-i18n-0.1-0.1.xpi

インストールもできちゃうのですね。すばらしい。
mew-browse.el もこれで最後にします。

CVS の contrib/mew-browse.el にこのパッチをあてておいてもらえま
せんか? > かずさん

## で、これから Wiki 書きますね。

-- 
白井秀行 (mailto:shirai at example.com)
-------------- next part --------------
Index: mew-browse.el
===================================================================
RCS file: /cvsmew/mew/contrib/mew-browse.el,v
retrieving revision 1.5
diff -u -r1.5 mew-browse.el
--- mew-browse.el	18 Oct 2004 08:55:46 -0000	1.5
+++ mew-browse.el	8 Nov 2004 10:10:40 -0000
@@ -3,7 +3,7 @@
 ;; Author: Hideyuki SHIRAI <shirai at example.com>
 ;; Modify: Shuichi Kitaguchi <kit at example.com>
 ;; Created: May 19, 1999
-;; Revised: Oct 15, 2004
+;; Revised: Nov 08, 2004
 
 ;;;
 ;;; ~/.emacs settings.
@@ -55,9 +55,9 @@
 ;;
 
 ;;; Use from Mozilla & Firefox with MozEx, set followings on Mailer form of MozEx.
-;; "/path/gnudoit (mew-url-mailto-mozex "%A" "%C" "%Z" "%S" "%B" "%r")"
+;; "/path/gnudoit (mew-url-mailto-mozex "%r")"
 ;; or
-;; "/path/emacseval (mew-url-mailto-mozex "%A" "%C" "%Z" "%S" "%B" "%r")"
+;; "/path/emacseval (mew-url-mailto-mozex "%r")"
 ;; 
 ;; `emacseval' is a shell scirpt like this,
 ;; ----cut here----
@@ -179,7 +179,7 @@
 	   (append mew-ext-prog-url-args (list url))))))
 
 (defun mew-url-mailto (url)
-  "Exec mew-user-agent-compose with parsing RFC2368.
+  "Execute mew-user-agent-compose with parsing RFC2368.
 
 If use from emacs-w3m, add followings in your ~/.emacs file.
   (setq w3m-mailto-url-function 'mew-url-mailto)
@@ -193,59 +193,38 @@
     (save-excursion
       (require 'mew)
       (mew-init)))
-  (mew-browse-url-mailto url))
-
-(defun mew-browse-url-mailto (url)
-  (let (lst)
-    (setq lst (mew-browse-url-mailto-analysis url))
+  (let ((lst (mew-browse-url-mailto-analysis url)))
     (mew-user-agent-compose (nth 0 lst)	;; to
 			    (nth 1 lst)	;; subject
 			    (nth 2 lst) ;; other
 			    nil mew-browse-url-mailto-switch-func)))
 
-(defun mew-url-mailto-mozex (&optional to cc bcc subject body url)
-  "Exec mew-user-agent-compose from Mozilla and Firefox with MozEx.
+(defun mew-url-mailto-mozex (url)
+  "Execute mew-user-agent-compose from Mozilla and Firefox with MozEx.
 
 If use this command, set followings on Mailer form of MozEx.
-\"/path/gnudoit (mew-url-mailto-mozex \"%A\" \"%C\" \"%Z\" \"%S\" \"%B\" \"%r\")\"
+\"/path/gnudoit (mew-url-mailto-mozex \"%r\")\"
 or
-\"/path/emacseval (mew-url-mailto-mozex \"%A\" \"%C\" \"%Z\" \"%S\" \"%B\" \"%r\")\"
+\"/path/emacseval (mew-url-mailto-mozex \"%r\")\"
 
 `emacseval' is a shell scirpt like this,
 ----cut here----
 #!/bin/sh
 /usr/local/bin/emacsclient --eval \"`echo $*`\"
 ----cut here----"
+  (interactive)
   (when (or (not (boundp 'mew-init-p)) (null mew-init-p))
     (save-excursion
       (require 'mew)
       (mew-init)))
-  (let ((dels '("To" "Subject" "Cc" "Bcc" "Body"))
-	(other (nth 2 (mew-browse-url-mailto-analysis (or url "")))))
-    (while dels
-      (setq other (delete (assoc (car dels) other) other))
-      (setq dels (cdr dels)))
-
-    (if (or (not to) (string= to ""))
-	(setq to nil)
-      (setq to (mew-browse-url-mailto-hex-to-string to)))
-    (if (or (not subject) (string= subject ""))
-	(setq subject nil)
-      (setq subject (mew-browse-url-mailto-hex-to-string subject)))
-    (unless (or (not cc) (string= cc ""))
-      (setq cc (mew-browse-url-mailto-hex-to-string cc))
-      (setq other (cons (cons "Cc" cc) other)))
-    (unless (or (not bcc) (string= bcc ""))
-      (setq bcc (mew-browse-url-mailto-hex-to-string bcc))
-      (setq other (cons (cons "Bcc" bcc) other)))
-    (unless (or (not body) (string= body ""))
-      (setq body (mew-browse-url-mailto-hex-to-string body))
-      (setq other (cons (cons "Body" body) other)))
-    (mew-user-agent-compose to subject other
+  (let ((lst (mew-browse-url-mailto-analysis url 'mozex)))
+    (mew-user-agent-compose (nth 0 lst)	;; to
+			    (nth 1 lst)	;; subject
+			    (nth 2 lst) ;; other
 			    nil mew-browse-url-mailto-switch-func)))
 
 ;; return '(to subject other)"
-(defun mew-browse-url-mailto-analysis (url)
+(defun mew-browse-url-mailto-analysis (url &optional mozex)
   (let (to subject other)
     (while (string-match "[ \t]+" url)
       (setq url (concat (substring url 0 (match-beginning 0))
@@ -262,6 +241,12 @@
 	    (hvalue (mew-browse-url-mailto-hex-to-string
 		     (substring url (match-beginning 2) (match-end 2)))))
 	(setq url (substring url (match-end 0)))
+	(when mozex
+	  (setq hname (mew-browse-url-mailto-hex-to-string hname))
+	  (while (string-match "[ \t\n]+" hname)
+	    (setq hname (replace-match "" nil nil hname)))
+	  (when (string-match "[ \t\n]+$" hvalue)
+	    (setq hvalue (replace-match "" nil nil hvalue))))
 	(cond
 	 ((string-match "^to$" hname)
 	  (if to


Mew-win32 メーリングリストの案内