emacs-orgmode@gnu.org archives
 help / color / mirror / code / Atom feed
* [PATCH] Add Microsoft Outlook Support to org-mac-link
@ 2013-09-07 20:29 Mike McLean
  2013-09-08  5:50 ` Carsten Dominik
  2013-09-08  5:58 ` Carsten Dominik
  0 siblings, 2 replies; 4+ messages in thread
From: Mike McLean @ 2013-09-07 20:29 UTC (permalink / raw)
  To: emacs-orgmode

* contrib/lisp/org-mac-link.el: Add “o”utlook to capture descriptors along with
functions to capture links from Microsoft Outlook for Mac.

The functions here replicate those that capture from Mail.app.
---
 contrib/lisp/org-mac-link.el | 140 +++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 140 insertions(+)

diff --git a/contrib/lisp/org-mac-link.el b/contrib/lisp/org-mac-link.el
index 59b88d2..2ff6711 100644
--- a/contrib/lisp/org-mac-link.el
+++ b/contrib/lisp/org-mac-link.el
@@ -13,6 +13,11 @@
 ;; Version: 1.1
 ;; Keywords: org, mac, hyperlink
 ;;
+;; Version: 1.2
+;; Keywords: outlook
+;; Author: Mike McLean <mike.mclean@pobox.com>
+;; Add support for Microsoft Outlook for Mac as Org mode links
+;;
 ;; This file is not part of GNU Emacs.
 ;;
 ;; This program is free software; you can redistribute it and/or modify
@@ -51,6 +56,7 @@
 ;; Google Chrome.app - Grab the url of the frontmost tab in the frontmost window
 ;; Together.app - Grab links to the selected items in the library list
 ;; Skim.app - Grab a link to the selected page in the topmost pdf document
+;; Microsoft Outlook.app - Grab a link to the selected message in the message list
 ;;
 ;;
 ;; Installation:
@@ -97,6 +103,12 @@ applications and inserting them in org documents"
   :group 'org-mac-link
   :type 'boolean)
 
+(defcustom org-mac-grab-Outlook-app-p t
+  "Enable menu option [o]utlook to grab links from Microsoft Outlook.app"
+  :tag "Grab Microsoft Outlook.app links"
+  :group 'org-mac-link
+  :type 'boolean)
+
 (defcustom org-mac-grab-Addressbook-app-p t
   "Enable menu option [a]ddressbook to grab links from AddressBook.app"
   :tag "Grab AddressBook.app links"
@@ -179,6 +191,7 @@ applications and inserting them in org documents"
   (interactive)
   (let* ((descriptors `(("F" "inder" org-mac-finder-insert-selected ,org-mac-grab-Finder-app-p)
                         ("m" "ail" org-mac-message-insert-selected ,org-mac-grab-Mail-app-p)
+                        ("o" "utlook" org-mac-outlook-message-insert-selected ,org-mac-grab-Outlook-app-p)
                         ("a" "ddressbook" org-mac-addressbook-insert-selected ,org-mac-grab-Addressbook-app-p)
                         ("s" "afari" org-mac-safari-insert-frontmost-url ,org-mac-grab-Safari-app-p)
                         ("f" "irefox" org-mac-firefox-insert-frontmost-url ,org-mac-grab-Firefox-app-p)
@@ -574,6 +587,133 @@ applications and inserting them in org documents"
 \f
 ;;
 ;;
+;; Handle links from Microsoft Outlook.app
+;;
+
+(org-add-link-type "mac-outlook" 'org-mac-outlook-message-open)
+
+(defun org-mac-outlook-message-open (msgid)
+  "Open a message in outlook"
+  (let* ((record-id-string (format "mdfind com_microsoft_outlook_recordID==%s" msgid))
+	(found-message (replace-regexp-in-string "\n$" ""
+              (shell-command-to-string record-id-string))))
+    (if (string= found-message "")
+      (message "org-mac-link: error could not find Outlook message %s" 	(substring-no-properties msgid))
+      (shell-command (format "open \"`mdfind com_microsoft_outlook_recordID==%s`\"" msgid)))))
+
+(defun org-as-get-selected-outlook-mail ()
+  "AppleScript to create links to selected messages in Microsoft Outlook.app."
+  (do-applescript
+   (concat
+    "tell application \"Microsoft Outlook\"\n"
+    "set msgCount to count current messages\n"
+    "if (msgCount < 1) then\n"
+    "return\n"
+    "end if\n"
+    "set theLinkList to {}\n"
+    "set theSelection to (get current messages)\n"
+    "repeat with theMessage in theSelection\n"
+    "set theID to id of theMessage as string\n"
+    "set theURL to \"mac-outlook:\" & theID\n"
+    "set theSubject to subject of theMessage\n"
+    "set theLink to theURL & \"::split::\" & theSubject & \"\n\"\n"
+    "copy theLink to end of theLinkList\n"
+    "end repeat\n"
+    "return theLinkList as string\n"
+    "end tell")))
+
+(defun org-sh-get-flagged-outlook-mail ()
+  "Shell commands to create links to flagged messages in Microsoft Outlook.app."
+  (mapconcat
+   (lambda (x) ""
+     (concat
+      "mac-outlook:"
+      (mapconcat
+       (lambda (y) "" y)
+       (split-string
+	(shell-command-to-string
+	 (format "mdls -raw -name com_microsoft_outlook_recordID -name kMDItemDisplayName \"%s\"" x))
+	"\000")
+       "::split::")
+      "\n"))
+   (with-temp-buffer
+     (let ((coding-system-for-read (or file-name-coding-system 'utf-8))
+	   (coding-system-for-write 'utf-8))
+       (shell-command
+	"mdfind com_microsoft_outlook_flagged==1"
+	(current-buffer)))
+     (split-string
+      (buffer-string) "\n" t))
+   ""))
+
+(defun org-mac-outlook-message-get-links (&optional select-or-flag)
+  "Create links to the messages currently selected or flagged in Microsoft Outlook.app.
+This will use AppleScript to get the message-id and the subject of the
+messages in Microsoft Outlook.app and make a link out of it.
+When SELECT-OR-FLAG is \"s\", get the selected messages (this is also
+the default).  When SELECT-OR-FLAG is \"f\", get the flagged messages.
+The Org-syntax text will be pushed to the kill ring, and also returned."
+  (interactive "sLink to (s)elected or (f)lagged messages: ")
+  (setq select-or-flag (or select-or-flag "s"))
+  (message "Org Mac Outlook: searching mailboxes...")
+  (let* ((as-link-list
+          (if (string= select-or-flag "s")
+              (org-as-get-selected-outlook-mail)
+	    (if (string= select-or-flag "f")
+		(org-sh-get-flagged-outlook-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 rtn orglink-list)
+    (while link-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)))
+    (setq rtn (mapconcat 'identity orglink-list "\n"))
+    (kill-new rtn)
+    rtn))
+
+(defun org-mac-outlook-message-insert-selected ()
+  "Insert a link to the messages currently selected in Microsoft Outlook.app.
+This will use AppleScript to get the message-id and the subject of the
+active mail in Microsoft Outlook.app and make a link out of it."
+  (interactive)
+  (insert (org-mac-outlook-message-get-links "s")))
+
+(defun org-mac-outlook-message-insert-flagged (org-buffer org-heading)
+  "Asks for an org buffer and a heading within it, and replace message links.
+If heading exists, delete all mac-outlook:// links within heading's first
+level.  If heading doesn't exist, create it at point-max.  Insert
+list of mac-outlook:// links to flagged mail after heading."
+  (interactive "bBuffer in which to insert links: \nsHeading after which to insert links: ")
+  (with-current-buffer org-buffer
+    (goto-char (point-min))
+    (let ((isearch-forward t)
+          (message-re "\\[\\[\\(mac-outlook:\\)\\([^]]+\\)\\]\\(\\[\\([^]]+\\)\\]\\)?\\]"))
+      (if (org-goto-local-search-headings org-heading nil t)
+          (if (not (eobp))
+              (progn
+                (save-excursion
+                  (while (re-search-forward
+                          message-re (save-excursion (outline-next-heading)) t)
+                    (delete-region (match-beginning 0) (match-end 0)))
+                  (insert "\n" (org-mac-outlook-message-get-links "f")))
+                (flush-lines "^$" (point) (outline-next-heading)))
+	    (insert "\n" (org-mac-outlook-message-get-links "f")))
+	(goto-char (point-max))
+	(insert "\n")
+	(org-insert-heading nil t)
+	(insert org-heading "\n" (org-mac-outlook-message-get-links "f"))))))
+
+
+\f
+;;
+;;
 ;; Handle links from Mail.app
 ;;
 
-- 
1.8.3.3

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH] Add Microsoft Outlook Support to org-mac-link
  2013-09-07 20:29 [PATCH] Add Microsoft Outlook Support to org-mac-link Mike McLean
@ 2013-09-08  5:50 ` Carsten Dominik
  2013-09-09 10:52   ` Mike McLean
  2013-09-08  5:58 ` Carsten Dominik
  1 sibling, 1 reply; 4+ messages in thread
From: Carsten Dominik @ 2013-09-08  5:50 UTC (permalink / raw)
  To: Mike McLean; +Cc: emacs-orgmode

[-- Attachment #1: Type: text/plain, Size: 8657 bytes --]

Hi Mike,

we don't need papers for contrib stuff - but let
me ask anyway:  Do you have signed FSF papers?

Thanks

- Carsten


On 7.9.2013, at 22:29, Mike McLean <mike.mclean@pobox.com> wrote:

> * contrib/lisp/org-mac-link.el: Add “o”utlook to capture descriptors along with
> functions to capture links from Microsoft Outlook for Mac.
> 
> The functions here replicate those that capture from Mail.app.
> ---
> contrib/lisp/org-mac-link.el | 140 +++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 140 insertions(+)
> 
> diff --git a/contrib/lisp/org-mac-link.el b/contrib/lisp/org-mac-link.el
> index 59b88d2..2ff6711 100644
> --- a/contrib/lisp/org-mac-link.el
> +++ b/contrib/lisp/org-mac-link.el
> @@ -13,6 +13,11 @@
> ;; Version: 1.1
> ;; Keywords: org, mac, hyperlink
> ;;
> +;; Version: 1.2
> +;; Keywords: outlook
> +;; Author: Mike McLean <mike.mclean@pobox.com>
> +;; Add support for Microsoft Outlook for Mac as Org mode links
> +;;
> ;; This file is not part of GNU Emacs.
> ;;
> ;; This program is free software; you can redistribute it and/or modify
> @@ -51,6 +56,7 @@
> ;; Google Chrome.app - Grab the url of the frontmost tab in the frontmost window
> ;; Together.app - Grab links to the selected items in the library list
> ;; Skim.app - Grab a link to the selected page in the topmost pdf document
> +;; Microsoft Outlook.app - Grab a link to the selected message in the message list
> ;;
> ;;
> ;; Installation:
> @@ -97,6 +103,12 @@ applications and inserting them in org documents"
>   :group 'org-mac-link
>   :type 'boolean)
> 
> +(defcustom org-mac-grab-Outlook-app-p t
> +  "Enable menu option [o]utlook to grab links from Microsoft Outlook.app"
> +  :tag "Grab Microsoft Outlook.app links"
> +  :group 'org-mac-link
> +  :type 'boolean)
> +
> (defcustom org-mac-grab-Addressbook-app-p t
>   "Enable menu option [a]ddressbook to grab links from AddressBook.app"
>   :tag "Grab AddressBook.app links"
> @@ -179,6 +191,7 @@ applications and inserting them in org documents"
>   (interactive)
>   (let* ((descriptors `(("F" "inder" org-mac-finder-insert-selected ,org-mac-grab-Finder-app-p)
>                         ("m" "ail" org-mac-message-insert-selected ,org-mac-grab-Mail-app-p)
> +                        ("o" "utlook" org-mac-outlook-message-insert-selected ,org-mac-grab-Outlook-app-p)
>                         ("a" "ddressbook" org-mac-addressbook-insert-selected ,org-mac-grab-Addressbook-app-p)
>                         ("s" "afari" org-mac-safari-insert-frontmost-url ,org-mac-grab-Safari-app-p)
>                         ("f" "irefox" org-mac-firefox-insert-frontmost-url ,org-mac-grab-Firefox-app-p)
> @@ -574,6 +587,133 @@ applications and inserting them in org documents"
> 
> ;;
> ;;
> +;; Handle links from Microsoft Outlook.app
> +;;
> +
> +(org-add-link-type "mac-outlook" 'org-mac-outlook-message-open)
> +
> +(defun org-mac-outlook-message-open (msgid)
> +  "Open a message in outlook"
> +  (let* ((record-id-string (format "mdfind com_microsoft_outlook_recordID==%s" msgid))
> +	(found-message (replace-regexp-in-string "\n$" ""
> +              (shell-command-to-string record-id-string))))
> +    (if (string= found-message "")
> +      (message "org-mac-link: error could not find Outlook message %s" 	(substring-no-properties msgid))
> +      (shell-command (format "open \"`mdfind com_microsoft_outlook_recordID==%s`\"" msgid)))))
> +
> +(defun org-as-get-selected-outlook-mail ()
> +  "AppleScript to create links to selected messages in Microsoft Outlook.app."
> +  (do-applescript
> +   (concat
> +    "tell application \"Microsoft Outlook\"\n"
> +    "set msgCount to count current messages\n"
> +    "if (msgCount < 1) then\n"
> +    "return\n"
> +    "end if\n"
> +    "set theLinkList to {}\n"
> +    "set theSelection to (get current messages)\n"
> +    "repeat with theMessage in theSelection\n"
> +    "set theID to id of theMessage as string\n"
> +    "set theURL to \"mac-outlook:\" & theID\n"
> +    "set theSubject to subject of theMessage\n"
> +    "set theLink to theURL & \"::split::\" & theSubject & \"\n\"\n"
> +    "copy theLink to end of theLinkList\n"
> +    "end repeat\n"
> +    "return theLinkList as string\n"
> +    "end tell")))
> +
> +(defun org-sh-get-flagged-outlook-mail ()
> +  "Shell commands to create links to flagged messages in Microsoft Outlook.app."
> +  (mapconcat
> +   (lambda (x) ""
> +     (concat
> +      "mac-outlook:"
> +      (mapconcat
> +       (lambda (y) "" y)
> +       (split-string
> +	(shell-command-to-string
> +	 (format "mdls -raw -name com_microsoft_outlook_recordID -name kMDItemDisplayName \"%s\"" x))
> +	"\000")
> +       "::split::")
> +      "\n"))
> +   (with-temp-buffer
> +     (let ((coding-system-for-read (or file-name-coding-system 'utf-8))
> +	   (coding-system-for-write 'utf-8))
> +       (shell-command
> +	"mdfind com_microsoft_outlook_flagged==1"
> +	(current-buffer)))
> +     (split-string
> +      (buffer-string) "\n" t))
> +   ""))
> +
> +(defun org-mac-outlook-message-get-links (&optional select-or-flag)
> +  "Create links to the messages currently selected or flagged in Microsoft Outlook.app.
> +This will use AppleScript to get the message-id and the subject of the
> +messages in Microsoft Outlook.app and make a link out of it.
> +When SELECT-OR-FLAG is \"s\", get the selected messages (this is also
> +the default).  When SELECT-OR-FLAG is \"f\", get the flagged messages.
> +The Org-syntax text will be pushed to the kill ring, and also returned."
> +  (interactive "sLink to (s)elected or (f)lagged messages: ")
> +  (setq select-or-flag (or select-or-flag "s"))
> +  (message "Org Mac Outlook: searching mailboxes...")
> +  (let* ((as-link-list
> +          (if (string= select-or-flag "s")
> +              (org-as-get-selected-outlook-mail)
> +	    (if (string= select-or-flag "f")
> +		(org-sh-get-flagged-outlook-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 rtn orglink-list)
> +    (while link-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)))
> +    (setq rtn (mapconcat 'identity orglink-list "\n"))
> +    (kill-new rtn)
> +    rtn))
> +
> +(defun org-mac-outlook-message-insert-selected ()
> +  "Insert a link to the messages currently selected in Microsoft Outlook.app.
> +This will use AppleScript to get the message-id and the subject of the
> +active mail in Microsoft Outlook.app and make a link out of it."
> +  (interactive)
> +  (insert (org-mac-outlook-message-get-links "s")))
> +
> +(defun org-mac-outlook-message-insert-flagged (org-buffer org-heading)
> +  "Asks for an org buffer and a heading within it, and replace message links.
> +If heading exists, delete all mac-outlook:// links within heading's first
> +level.  If heading doesn't exist, create it at point-max.  Insert
> +list of mac-outlook:// links to flagged mail after heading."
> +  (interactive "bBuffer in which to insert links: \nsHeading after which to insert links: ")
> +  (with-current-buffer org-buffer
> +    (goto-char (point-min))
> +    (let ((isearch-forward t)
> +          (message-re "\\[\\[\\(mac-outlook:\\)\\([^]]+\\)\\]\\(\\[\\([^]]+\\)\\]\\)?\\]"))
> +      (if (org-goto-local-search-headings org-heading nil t)
> +          (if (not (eobp))
> +              (progn
> +                (save-excursion
> +                  (while (re-search-forward
> +                          message-re (save-excursion (outline-next-heading)) t)
> +                    (delete-region (match-beginning 0) (match-end 0)))
> +                  (insert "\n" (org-mac-outlook-message-get-links "f")))
> +                (flush-lines "^$" (point) (outline-next-heading)))
> +	    (insert "\n" (org-mac-outlook-message-get-links "f")))
> +	(goto-char (point-max))
> +	(insert "\n")
> +	(org-insert-heading nil t)
> +	(insert org-heading "\n" (org-mac-outlook-message-get-links "f"))))))
> +
> +
> +\f
> +;;
> +;;
> ;; Handle links from Mail.app
> ;;
> 
> -- 
> 1.8.3.3
> 
> 


[-- Attachment #2: Message signed with OpenPGP using GPGMail --]
[-- Type: application/pgp-signature, Size: 163 bytes --]

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH] Add Microsoft Outlook Support to org-mac-link
  2013-09-07 20:29 [PATCH] Add Microsoft Outlook Support to org-mac-link Mike McLean
  2013-09-08  5:50 ` Carsten Dominik
@ 2013-09-08  5:58 ` Carsten Dominik
  1 sibling, 0 replies; 4+ messages in thread
From: Carsten Dominik @ 2013-09-08  5:58 UTC (permalink / raw)
  To: Mike McLean; +Cc: emacs-orgmode

[-- Attachment #1: Type: text/plain, Size: 8553 bytes --]

Applied, thanks.

- Carsten

On 7.9.2013, at 22:29, Mike McLean <mike.mclean@pobox.com> wrote:

> * contrib/lisp/org-mac-link.el: Add “o”utlook to capture descriptors along with
> functions to capture links from Microsoft Outlook for Mac.
> 
> The functions here replicate those that capture from Mail.app.
> ---
> contrib/lisp/org-mac-link.el | 140 +++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 140 insertions(+)
> 
> diff --git a/contrib/lisp/org-mac-link.el b/contrib/lisp/org-mac-link.el
> index 59b88d2..2ff6711 100644
> --- a/contrib/lisp/org-mac-link.el
> +++ b/contrib/lisp/org-mac-link.el
> @@ -13,6 +13,11 @@
> ;; Version: 1.1
> ;; Keywords: org, mac, hyperlink
> ;;
> +;; Version: 1.2
> +;; Keywords: outlook
> +;; Author: Mike McLean <mike.mclean@pobox.com>
> +;; Add support for Microsoft Outlook for Mac as Org mode links
> +;;
> ;; This file is not part of GNU Emacs.
> ;;
> ;; This program is free software; you can redistribute it and/or modify
> @@ -51,6 +56,7 @@
> ;; Google Chrome.app - Grab the url of the frontmost tab in the frontmost window
> ;; Together.app - Grab links to the selected items in the library list
> ;; Skim.app - Grab a link to the selected page in the topmost pdf document
> +;; Microsoft Outlook.app - Grab a link to the selected message in the message list
> ;;
> ;;
> ;; Installation:
> @@ -97,6 +103,12 @@ applications and inserting them in org documents"
>   :group 'org-mac-link
>   :type 'boolean)
> 
> +(defcustom org-mac-grab-Outlook-app-p t
> +  "Enable menu option [o]utlook to grab links from Microsoft Outlook.app"
> +  :tag "Grab Microsoft Outlook.app links"
> +  :group 'org-mac-link
> +  :type 'boolean)
> +
> (defcustom org-mac-grab-Addressbook-app-p t
>   "Enable menu option [a]ddressbook to grab links from AddressBook.app"
>   :tag "Grab AddressBook.app links"
> @@ -179,6 +191,7 @@ applications and inserting them in org documents"
>   (interactive)
>   (let* ((descriptors `(("F" "inder" org-mac-finder-insert-selected ,org-mac-grab-Finder-app-p)
>                         ("m" "ail" org-mac-message-insert-selected ,org-mac-grab-Mail-app-p)
> +                        ("o" "utlook" org-mac-outlook-message-insert-selected ,org-mac-grab-Outlook-app-p)
>                         ("a" "ddressbook" org-mac-addressbook-insert-selected ,org-mac-grab-Addressbook-app-p)
>                         ("s" "afari" org-mac-safari-insert-frontmost-url ,org-mac-grab-Safari-app-p)
>                         ("f" "irefox" org-mac-firefox-insert-frontmost-url ,org-mac-grab-Firefox-app-p)
> @@ -574,6 +587,133 @@ applications and inserting them in org documents"
> 
> ;;
> ;;
> +;; Handle links from Microsoft Outlook.app
> +;;
> +
> +(org-add-link-type "mac-outlook" 'org-mac-outlook-message-open)
> +
> +(defun org-mac-outlook-message-open (msgid)
> +  "Open a message in outlook"
> +  (let* ((record-id-string (format "mdfind com_microsoft_outlook_recordID==%s" msgid))
> +	(found-message (replace-regexp-in-string "\n$" ""
> +              (shell-command-to-string record-id-string))))
> +    (if (string= found-message "")
> +      (message "org-mac-link: error could not find Outlook message %s" 	(substring-no-properties msgid))
> +      (shell-command (format "open \"`mdfind com_microsoft_outlook_recordID==%s`\"" msgid)))))
> +
> +(defun org-as-get-selected-outlook-mail ()
> +  "AppleScript to create links to selected messages in Microsoft Outlook.app."
> +  (do-applescript
> +   (concat
> +    "tell application \"Microsoft Outlook\"\n"
> +    "set msgCount to count current messages\n"
> +    "if (msgCount < 1) then\n"
> +    "return\n"
> +    "end if\n"
> +    "set theLinkList to {}\n"
> +    "set theSelection to (get current messages)\n"
> +    "repeat with theMessage in theSelection\n"
> +    "set theID to id of theMessage as string\n"
> +    "set theURL to \"mac-outlook:\" & theID\n"
> +    "set theSubject to subject of theMessage\n"
> +    "set theLink to theURL & \"::split::\" & theSubject & \"\n\"\n"
> +    "copy theLink to end of theLinkList\n"
> +    "end repeat\n"
> +    "return theLinkList as string\n"
> +    "end tell")))
> +
> +(defun org-sh-get-flagged-outlook-mail ()
> +  "Shell commands to create links to flagged messages in Microsoft Outlook.app."
> +  (mapconcat
> +   (lambda (x) ""
> +     (concat
> +      "mac-outlook:"
> +      (mapconcat
> +       (lambda (y) "" y)
> +       (split-string
> +	(shell-command-to-string
> +	 (format "mdls -raw -name com_microsoft_outlook_recordID -name kMDItemDisplayName \"%s\"" x))
> +	"\000")
> +       "::split::")
> +      "\n"))
> +   (with-temp-buffer
> +     (let ((coding-system-for-read (or file-name-coding-system 'utf-8))
> +	   (coding-system-for-write 'utf-8))
> +       (shell-command
> +	"mdfind com_microsoft_outlook_flagged==1"
> +	(current-buffer)))
> +     (split-string
> +      (buffer-string) "\n" t))
> +   ""))
> +
> +(defun org-mac-outlook-message-get-links (&optional select-or-flag)
> +  "Create links to the messages currently selected or flagged in Microsoft Outlook.app.
> +This will use AppleScript to get the message-id and the subject of the
> +messages in Microsoft Outlook.app and make a link out of it.
> +When SELECT-OR-FLAG is \"s\", get the selected messages (this is also
> +the default).  When SELECT-OR-FLAG is \"f\", get the flagged messages.
> +The Org-syntax text will be pushed to the kill ring, and also returned."
> +  (interactive "sLink to (s)elected or (f)lagged messages: ")
> +  (setq select-or-flag (or select-or-flag "s"))
> +  (message "Org Mac Outlook: searching mailboxes...")
> +  (let* ((as-link-list
> +          (if (string= select-or-flag "s")
> +              (org-as-get-selected-outlook-mail)
> +	    (if (string= select-or-flag "f")
> +		(org-sh-get-flagged-outlook-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 rtn orglink-list)
> +    (while link-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)))
> +    (setq rtn (mapconcat 'identity orglink-list "\n"))
> +    (kill-new rtn)
> +    rtn))
> +
> +(defun org-mac-outlook-message-insert-selected ()
> +  "Insert a link to the messages currently selected in Microsoft Outlook.app.
> +This will use AppleScript to get the message-id and the subject of the
> +active mail in Microsoft Outlook.app and make a link out of it."
> +  (interactive)
> +  (insert (org-mac-outlook-message-get-links "s")))
> +
> +(defun org-mac-outlook-message-insert-flagged (org-buffer org-heading)
> +  "Asks for an org buffer and a heading within it, and replace message links.
> +If heading exists, delete all mac-outlook:// links within heading's first
> +level.  If heading doesn't exist, create it at point-max.  Insert
> +list of mac-outlook:// links to flagged mail after heading."
> +  (interactive "bBuffer in which to insert links: \nsHeading after which to insert links: ")
> +  (with-current-buffer org-buffer
> +    (goto-char (point-min))
> +    (let ((isearch-forward t)
> +          (message-re "\\[\\[\\(mac-outlook:\\)\\([^]]+\\)\\]\\(\\[\\([^]]+\\)\\]\\)?\\]"))
> +      (if (org-goto-local-search-headings org-heading nil t)
> +          (if (not (eobp))
> +              (progn
> +                (save-excursion
> +                  (while (re-search-forward
> +                          message-re (save-excursion (outline-next-heading)) t)
> +                    (delete-region (match-beginning 0) (match-end 0)))
> +                  (insert "\n" (org-mac-outlook-message-get-links "f")))
> +                (flush-lines "^$" (point) (outline-next-heading)))
> +	    (insert "\n" (org-mac-outlook-message-get-links "f")))
> +	(goto-char (point-max))
> +	(insert "\n")
> +	(org-insert-heading nil t)
> +	(insert org-heading "\n" (org-mac-outlook-message-get-links "f"))))))
> +
> +
> +\f
> +;;
> +;;
> ;; Handle links from Mail.app
> ;;
> 
> -- 
> 1.8.3.3
> 
> 


[-- Attachment #2: Message signed with OpenPGP using GPGMail --]
[-- Type: application/pgp-signature, Size: 163 bytes --]

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH] Add Microsoft Outlook Support to org-mac-link
  2013-09-08  5:50 ` Carsten Dominik
@ 2013-09-09 10:52   ` Mike McLean
  0 siblings, 0 replies; 4+ messages in thread
From: Mike McLean @ 2013-09-09 10:52 UTC (permalink / raw)
  To: Carsten Dominik; +Cc: emacs-orgmode

[-- Attachment #1: Type: text/plain, Size: 9461 bytes --]

I don't and I do need to check with my current employer before I could sign
them (*I* don't have a problem with it, but I'm just not sure of the
policies).


On Sun, Sep 8, 2013 at 1:50 AM, Carsten Dominik
<carsten.dominik@gmail.com>wrote:

> Hi Mike,
>
> we don't need papers for contrib stuff - but let
> me ask anyway:  Do you have signed FSF papers?
>
> Thanks
>
> - Carsten
>
>
> On 7.9.2013, at 22:29, Mike McLean <mike.mclean@pobox.com> wrote:
>
> > * contrib/lisp/org-mac-link.el: Add “o”utlook to capture descriptors
> along with
> > functions to capture links from Microsoft Outlook for Mac.
> >
> > The functions here replicate those that capture from Mail.app.
> > ---
> > contrib/lisp/org-mac-link.el | 140
> +++++++++++++++++++++++++++++++++++++++++++
> > 1 file changed, 140 insertions(+)
> >
> > diff --git a/contrib/lisp/org-mac-link.el b/contrib/lisp/org-mac-link.el
> > index 59b88d2..2ff6711 100644
> > --- a/contrib/lisp/org-mac-link.el
> > +++ b/contrib/lisp/org-mac-link.el
> > @@ -13,6 +13,11 @@
> > ;; Version: 1.1
> > ;; Keywords: org, mac, hyperlink
> > ;;
> > +;; Version: 1.2
> > +;; Keywords: outlook
> > +;; Author: Mike McLean <mike.mclean@pobox.com>
> > +;; Add support for Microsoft Outlook for Mac as Org mode links
> > +;;
> > ;; This file is not part of GNU Emacs.
> > ;;
> > ;; This program is free software; you can redistribute it and/or modify
> > @@ -51,6 +56,7 @@
> > ;; Google Chrome.app - Grab the url of the frontmost tab in the
> frontmost window
> > ;; Together.app - Grab links to the selected items in the library list
> > ;; Skim.app - Grab a link to the selected page in the topmost pdf
> document
> > +;; Microsoft Outlook.app - Grab a link to the selected message in the
> message list
> > ;;
> > ;;
> > ;; Installation:
> > @@ -97,6 +103,12 @@ applications and inserting them in org documents"
> >   :group 'org-mac-link
> >   :type 'boolean)
> >
> > +(defcustom org-mac-grab-Outlook-app-p t
> > +  "Enable menu option [o]utlook to grab links from Microsoft
> Outlook.app"
> > +  :tag "Grab Microsoft Outlook.app links"
> > +  :group 'org-mac-link
> > +  :type 'boolean)
> > +
> > (defcustom org-mac-grab-Addressbook-app-p t
> >   "Enable menu option [a]ddressbook to grab links from AddressBook.app"
> >   :tag "Grab AddressBook.app links"
> > @@ -179,6 +191,7 @@ applications and inserting them in org documents"
> >   (interactive)
> >   (let* ((descriptors `(("F" "inder" org-mac-finder-insert-selected
> ,org-mac-grab-Finder-app-p)
> >                         ("m" "ail" org-mac-message-insert-selected
> ,org-mac-grab-Mail-app-p)
> > +                        ("o" "utlook"
> org-mac-outlook-message-insert-selected ,org-mac-grab-Outlook-app-p)
> >                         ("a" "ddressbook"
> org-mac-addressbook-insert-selected ,org-mac-grab-Addressbook-app-p)
> >                         ("s" "afari" org-mac-safari-insert-frontmost-url
> ,org-mac-grab-Safari-app-p)
> >                         ("f" "irefox"
> org-mac-firefox-insert-frontmost-url ,org-mac-grab-Firefox-app-p)
> > @@ -574,6 +587,133 @@ applications and inserting them in org documents"
> >
> > ;;
> > ;;
> > +;; Handle links from Microsoft Outlook.app
> > +;;
> > +
> > +(org-add-link-type "mac-outlook" 'org-mac-outlook-message-open)
> > +
> > +(defun org-mac-outlook-message-open (msgid)
> > +  "Open a message in outlook"
> > +  (let* ((record-id-string (format "mdfind
> com_microsoft_outlook_recordID==%s" msgid))
> > +     (found-message (replace-regexp-in-string "\n$" ""
> > +              (shell-command-to-string record-id-string))))
> > +    (if (string= found-message "")
> > +      (message "org-mac-link: error could not find Outlook message %s"
>       (substring-no-properties msgid))
> > +      (shell-command (format "open \"`mdfind
> com_microsoft_outlook_recordID==%s`\"" msgid)))))
> > +
> > +(defun org-as-get-selected-outlook-mail ()
> > +  "AppleScript to create links to selected messages in Microsoft
> Outlook.app."
> > +  (do-applescript
> > +   (concat
> > +    "tell application \"Microsoft Outlook\"\n"
> > +    "set msgCount to count current messages\n"
> > +    "if (msgCount < 1) then\n"
> > +    "return\n"
> > +    "end if\n"
> > +    "set theLinkList to {}\n"
> > +    "set theSelection to (get current messages)\n"
> > +    "repeat with theMessage in theSelection\n"
> > +    "set theID to id of theMessage as string\n"
> > +    "set theURL to \"mac-outlook:\" & theID\n"
> > +    "set theSubject to subject of theMessage\n"
> > +    "set theLink to theURL & \"::split::\" & theSubject & \"\n\"\n"
> > +    "copy theLink to end of theLinkList\n"
> > +    "end repeat\n"
> > +    "return theLinkList as string\n"
> > +    "end tell")))
> > +
> > +(defun org-sh-get-flagged-outlook-mail ()
> > +  "Shell commands to create links to flagged messages in Microsoft
> Outlook.app."
> > +  (mapconcat
> > +   (lambda (x) ""
> > +     (concat
> > +      "mac-outlook:"
> > +      (mapconcat
> > +       (lambda (y) "" y)
> > +       (split-string
> > +     (shell-command-to-string
> > +      (format "mdls -raw -name com_microsoft_outlook_recordID -name
> kMDItemDisplayName \"%s\"" x))
> > +     "\000")
> > +       "::split::")
> > +      "\n"))
> > +   (with-temp-buffer
> > +     (let ((coding-system-for-read (or file-name-coding-system 'utf-8))
> > +        (coding-system-for-write 'utf-8))
> > +       (shell-command
> > +     "mdfind com_microsoft_outlook_flagged==1"
> > +     (current-buffer)))
> > +     (split-string
> > +      (buffer-string) "\n" t))
> > +   ""))
> > +
> > +(defun org-mac-outlook-message-get-links (&optional select-or-flag)
> > +  "Create links to the messages currently selected or flagged in
> Microsoft Outlook.app.
> > +This will use AppleScript to get the message-id and the subject of the
> > +messages in Microsoft Outlook.app and make a link out of it.
> > +When SELECT-OR-FLAG is \"s\", get the selected messages (this is also
> > +the default).  When SELECT-OR-FLAG is \"f\", get the flagged messages.
> > +The Org-syntax text will be pushed to the kill ring, and also returned."
> > +  (interactive "sLink to (s)elected or (f)lagged messages: ")
> > +  (setq select-or-flag (or select-or-flag "s"))
> > +  (message "Org Mac Outlook: searching mailboxes...")
> > +  (let* ((as-link-list
> > +          (if (string= select-or-flag "s")
> > +              (org-as-get-selected-outlook-mail)
> > +         (if (string= select-or-flag "f")
> > +             (org-sh-get-flagged-outlook-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 rtn
> orglink-list)
> > +    (while link-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)))
> > +    (setq rtn (mapconcat 'identity orglink-list "\n"))
> > +    (kill-new rtn)
> > +    rtn))
> > +
> > +(defun org-mac-outlook-message-insert-selected ()
> > +  "Insert a link to the messages currently selected in Microsoft
> Outlook.app.
> > +This will use AppleScript to get the message-id and the subject of the
> > +active mail in Microsoft Outlook.app and make a link out of it."
> > +  (interactive)
> > +  (insert (org-mac-outlook-message-get-links "s")))
> > +
> > +(defun org-mac-outlook-message-insert-flagged (org-buffer org-heading)
> > +  "Asks for an org buffer and a heading within it, and replace message
> links.
> > +If heading exists, delete all mac-outlook:// links within heading's
> first
> > +level.  If heading doesn't exist, create it at point-max.  Insert
> > +list of mac-outlook:// links to flagged mail after heading."
> > +  (interactive "bBuffer in which to insert links: \nsHeading after
> which to insert links: ")
> > +  (with-current-buffer org-buffer
> > +    (goto-char (point-min))
> > +    (let ((isearch-forward t)
> > +          (message-re
> "\\[\\[\\(mac-outlook:\\)\\([^]]+\\)\\]\\(\\[\\([^]]+\\)\\]\\)?\\]"))
> > +      (if (org-goto-local-search-headings org-heading nil t)
> > +          (if (not (eobp))
> > +              (progn
> > +                (save-excursion
> > +                  (while (re-search-forward
> > +                          message-re (save-excursion
> (outline-next-heading)) t)
> > +                    (delete-region (match-beginning 0) (match-end 0)))
> > +                  (insert "\n" (org-mac-outlook-message-get-links "f")))
> > +                (flush-lines "^$" (point) (outline-next-heading)))
> > +         (insert "\n" (org-mac-outlook-message-get-links "f")))
> > +     (goto-char (point-max))
> > +     (insert "\n")
> > +     (org-insert-heading nil t)
> > +     (insert org-heading "\n" (org-mac-outlook-message-get-links
> "f"))))))
> > +
> > +
> > +
> > +;;
> > +;;
> > ;; Handle links from Mail.app
> > ;;
> >
> > --
> > 1.8.3.3
> >
> >
>
>

[-- Attachment #2: Type: text/html, Size: 12211 bytes --]

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2013-09-09 10:53 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-09-07 20:29 [PATCH] Add Microsoft Outlook Support to org-mac-link Mike McLean
2013-09-08  5:50 ` Carsten Dominik
2013-09-09 10:52   ` Mike McLean
2013-09-08  5:58 ` Carsten Dominik

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).