From: Christopher Suckling <suckling.list@googlemail.com>
To: Carsten Dominik <carsten.dominik@gmail.com>
Cc: emacs-orgmode emacs-orgmode <emacs-orgmode@gnu.org>,
Christopher Suckling <suckling.list@googlemail.com>
Subject: Re: Problem with org-mac-message.el
Date: Sat, 4 Apr 2009 08:18:27 +0100 [thread overview]
Message-ID: <4DDA3A2E-81DA-4FAE-8D96-68D5E38E6667@gmail.com> (raw)
In-Reply-To: <A6BBFE99-E9F0-4F55-A1B6-EEE647173199@gmail.com>
[-- Attachment #1: Type: text/plain, Size: 1403 bytes --]
On 3 Apr 2009, at 17:58, Carsten Dominik wrote:
>
> On Apr 3, 2009, at 4:49 PM, Christopher Suckling wrote:
>
>>
>> On 1 Apr 2009, at 21:21, Ed Hirgelt wrote:
>>
>>> I've found that org-mac-message-get-link has a problem inserting
>>> [["]] as the first item.
>>
>> I can't replicate this. Could you provide an example?
>>
>>> The following change makes it better...
>>
>> Unfortunately, this change breaks the code for all other
>> possibilities, and, if I understand the problem correctly, simply
>> omits a link that begins [["
>>
>> My beginner's elisp is rather clumsy; I'm going to attempt to tidy
>> up the code anyway, so I'll be on the lookout for your difficulty
>> whilst I do so.
>
> I think I already fixed it.....
>
Thanks! I've never used mapcar before...
I've made things more modular so that your changes are reflected in
searches for both selected and flagged mail.
In doing so, I may have been rather naughty - I've changed the
function names so that they are consistent:
(org-mac-message-insert-link) becomes (org-mac-message-insert-selected)
(org-mac-create-flagged-mail) becomes (org-mac-message-insert-flagged)
both of which call the function (org-mac-message-get-links) to do
their stuff.
If this is not on, then I'll resubmit the patch with the original
function names.
Otherwise, new documentation is primed for pushing to Worg.
Best,
Christopher
[-- Attachment #2: org-mac-message.patch --]
[-- Type: application/octet-stream, Size: 6583 bytes --]
diff --git a/lisp/org-mac-message.el b/lisp/org-mac-message.el
index 87cdea5..720b7e5 100644
--- a/lisp/org-mac-message.el
+++ b/lisp/org-mac-message.el
@@ -42,7 +42,7 @@
;; If you have Growl installed and would like more visual feedback
;; whilst AppleScript searches for messages, please uncomment lines
-;; 125 to 130.
+;; 114 to 119.
;;; Code:
@@ -81,64 +81,25 @@ This will use the command `open' with the message URL."
(start-process (concat "open message:" message-id) nil
"open" (concat "message://<" (substring message-id 2) ">")))
-(defun org-mac-message-insert-link ()
- "Insert a link to the messages currently selected in Apple Mail.
-This will use applescript to get the message-id and the subject of the
-active mail in AppleMail and make a link out of it."
- (interactive)
- (org-mac-message-get-link)
- (yank))
-
-(defun org-mac-message-get-link ()
- "Insert a link to the messages currently selected in Apple Mail.
-This will use applescript to get the message-id and the subject of the
-active mail in AppleMail and make a link out of it."
- (let* ((as-link-list
- (do-applescript
- (concat
- "tell application \"Mail\"\n"
- "set theLinkList to {}\n"
- "set theSelection to selection\n"
- "repeat with theMessage in theSelection\n"
- "set theID to message id of theMessage\n"
- "set theSubject to subject of theMessage\n"
- "set theLink to \"message://\" & theID & \"::split::\" & theSubject & \"\n\"\n"
- "copy theLink to end of theLinkList\n"
- "end repeat\n"
- "return theLinkList as string\n"
- "end tell")))
- (link-list
- (mapcar
- (lambda (x) (if (string-match "\\`\"\\(.*\\)\"\\'" x) (setq x (match-string 1 x))) x)
- (split-string as-link-list "[\r\n]+")))
- split-link
- URL
- description
- orglink
- orglink-insert
- (orglink-list nil))
- (while link-list
- (progn
- (setq split-link (split-string (pop link-list) "::split::"))
- (setq URL (car split-link))
- (setq description (cadr split-link))
- (if (not (string= URL ""))
- (progn
- (setq orglink (org-make-link-string URL description))
- (push orglink orglink-list)))))
- (with-temp-buffer
- (while orglink-list
- (insert (concat (pop orglink-list)) "\n"))
- (kill-region (point-min) (point-max))
- (current-kill 0))))
-
-(defun org-mac-create-flagged-mail ()
- "Create links to flagged messages in a Mail.app account and
-copy them to the kill ring"
- (interactive)
- (message "AppleScript: searching mailboxes...")
- (let* ((as-link-list
- (do-applescript
+(defun as-get-selected-mail ()
+ "AppleScript to create links to selected messages in Mail.app"
+ (do-applescript
+ (concat
+ "tell application \"Mail\"\n"
+ "set theLinkList to {}\n"
+ "set theSelection to selection\n"
+ "repeat with theMessage in theSelection\n"
+ "set theID to message id of theMessage\n"
+ "set theSubject to subject of theMessage\n"
+ "set theLink to \"message://\" & theID & \"::split::\" & theSubject & \"\n\"\n"
+ "copy theLink to end of theLinkList\n"
+ "end repeat\n"
+ "return theLinkList as string\n"
+ "end tell")))
+
+(defun as-get-flagged-mail ()
+ "AppleScript to create links to flagged messages in Mail.app"
+ (do-applescript
(concat
"tell application \"Mail\"\n"
"set theMailboxes to every mailbox of account \"" org-mac-mail-account "\"\n"
@@ -160,28 +121,53 @@ copy them to the kill ring"
"end repeat\n"
"return theLinkList as string\n"
"end tell")))
- (link-list (split-string as-link-list "\n"))
+
+(defun org-mac-message-get-links (select-or-flag)
+ "Create links to the messages currently selected or flagged in
+Mail.app. This will use AppleScript to get the message-id and
+the subject of the message in Mail.app and make a link out
+of it."
+ (interactive "sLink to (s)elected or (f)lagged messages: ")
+ (message "AppleScript: searching mailboxes...")
+ (let* ((as-link-list
+ (if (string= select-or-flag "s")
+ (as-get-selected-mail)
+ (if (string= select-or-flag "f")
+ (as-get-flagged-mail)
+ (error "Please select \"s\" or \"f\""))))
+ (link-list
+ (mapcar
+ (lambda (x) (if (string-match "\\`\"\\(.*\\)\"\\'" x) (setq x (match-string 1 x))) x)
+ (split-string as-link-list "[\r\n]+")))
split-link
URL
description
orglink
+ orglink-insert
(orglink-list nil))
(while link-list
- (progn
- (setq split-link (split-string (pop link-list) "::split::"))
- (setq URL (car split-link))
- (setq description (cadr split-link))
- (if (not (string= URL ""))
- (progn
- (setq orglink (org-make-link-string URL description))
- (push orglink orglink-list)))))
+ (setq split-link (split-string (pop link-list) "::split::"))
+ (setq URL (car split-link))
+ (setq description (cadr split-link))
+ (when (not (string= URL ""))
+ (setq orglink (org-make-link-string URL description))
+ (push orglink orglink-list)))
(with-temp-buffer
(while orglink-list
(insert (concat (pop orglink-list)) "\n"))
(kill-region (point-min) (point-max))
- (message "Flagged messages copied to kill ring"))))
+ (current-kill 0)))
+ (message "Messages copied to kill-ring"))
+
+(defun org-mac-message-insert-selected ()
+ "Insert a link to the messages currently selected in Apple Mail.
+This will use applescript to get the message-id and the subject of the
+active mail in AppleMail and make a link out of it."
+ (interactive)
+ (org-mac-message-get-links "s")
+ (yank))
-(defun org-mac-insert-flagged-mail (org-buffer org-heading)
+(defun org-mac-message-insert-flagged (org-buffer org-heading)
"Asks for an org buffer and a heading within it. If heading
exists, delete all message:// links within heading's first
level. If heading doesn't exist, create it at point-max. Insert
@@ -199,17 +185,17 @@ list of message:// links to flagged mail after heading."
(while (re-search-forward message-re (save-excursion (outline-next-heading)) t)
(delete-region (match-beginning 0) (match-end 0)))
- (org-mac-create-flagged-mail)
+ (org-mac-message-get-links "f")
(yank))
(flush-lines "^$" (point) (outline-next-heading)))
(insert "\n")
- (org-mac-create-flagged-mail)
+ (org-mac-message-get-links "f")
(yank))
(goto-char (point-max))
(insert "\n")
(org-insert-heading)
(insert (concat org-heading "\n"))
- (org-mac-create-flagged-mail)
+ (org-mac-message-get-links "f")
(yank)))))
(provide 'org-mac-message)
[-- Attachment #3: Type: text/plain, Size: 1 bytes --]
[-- Attachment #4: Type: text/plain, Size: 204 bytes --]
_______________________________________________
Emacs-orgmode mailing list
Remember: use `Reply All' to send replies to the list.
Emacs-orgmode@gnu.org
http://lists.gnu.org/mailman/listinfo/emacs-orgmode
next prev parent reply other threads:[~2009-04-04 7:18 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-04-01 20:21 Problem with org-mac-message.el Ed Hirgelt
2009-04-03 14:49 ` Christopher Suckling
2009-04-03 16:58 ` Carsten Dominik
2009-04-04 7:18 ` Christopher Suckling [this message]
2009-04-04 8:25 ` Carsten Dominik
2009-04-04 8:52 ` Christopher Suckling
2009-04-04 10:33 ` Carsten Dominik
2009-04-05 21:43 ` Christopher Suckling
2009-04-06 4:44 ` Carsten Dominik
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.orgmode.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4DDA3A2E-81DA-4FAE-8D96-68D5E38E6667@gmail.com \
--to=suckling.list@googlemail.com \
--cc=carsten.dominik@gmail.com \
--cc=emacs-orgmode@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).