+ "@distorted.org.uk")))
+ ("^nnimap\\+[^:]+-chiark:"
+ ("X-mdw-Send-Mail" "chiark-smtp"))
+ ("^nnimap\\+google:"
+ (address "distorted.mdw@gmail.com")
+ ("X-mdw-Send-Mail" "gmail-smtp"))))
+
+(require 'nnmail)
+(setq nnmail-split-abbrev-alist
+ (mdw-uniquify-alist
+ `((to . ,(concat "to\\|cc\\|apparently-to\\|envelope-to\\|"
+ "resent-to\\|resent-cc"))
+ (any . ,(concat "from\\|sender\\|resent-from\\|"
+ "to\\|cc\\|apparently-to\\|envelope-to\\|"
+ "resent-to\\|resent-cc"))
+ ,@nnmail-split-abbrev-alist)))
+
+(defvar mdw-odin-parse-regexp
+ (concat "^"
+ "\\S-+" "\\s-+" ; time limit
+ "\\(" "\\S-+" "\\)" "\\s-+" ; local part
+ "\\S-+" "\\s-+" ; recipient email address
+ "=" "\\(" "\\S-+" "\\)" ; mailbox tag
+ "\\(" "$" "\\|" "\\s-" "\\)"))
+
+(defun mdw-odin-splits ()
+ (let ((list nil))
+ (with-temp-buffer
+ (call-process "ssh" nil t nil
+ "stratocaster" "userv" "odin" "mail" "list")
+ (goto-char (point-min))
+ (while (< (point) (point-max))
+ (when (looking-at mdw-odin-parse-regexp)
+ (let ((local-part (match-string 1))
+ (tag (match-string 2)))
+ (push `(to ,(format "%s@odin\\.gg" local-part)
+ ,(format "crap.%s" tag))
+ list)))
+ (forward-line)))
+ (nreverse list)))