2007-05-10 18:44:49 +00:00
|
|
|
;;; gnus-diary.el --- Wrapper around the NNDiary Gnus back end
|
2004-09-04 13:13:48 +00:00
|
|
|
|
2016-01-01 09:16:19 +00:00
|
|
|
;; Copyright (C) 1999-2016 Free Software Foundation, Inc.
|
2004-09-04 13:13:48 +00:00
|
|
|
|
|
|
|
;; Author: Didier Verna <didier@xemacs.org>
|
|
|
|
;; Maintainer: Didier Verna <didier@xemacs.org>
|
|
|
|
;; Created: Tue Jul 20 10:42:55 1999
|
|
|
|
;; Keywords: calendar mail news
|
|
|
|
|
|
|
|
;; This file is part of GNU Emacs.
|
|
|
|
|
2008-05-06 03:56:49 +00:00
|
|
|
;; GNU Emacs is free software: you can redistribute it and/or modify
|
|
|
|
;; it under the terms of the GNU General Public License as published by
|
|
|
|
;; the Free Software Foundation, either version 3 of the License, or
|
|
|
|
;; (at your option) any later version.
|
2004-09-04 13:13:48 +00:00
|
|
|
|
2008-05-06 03:56:49 +00:00
|
|
|
;; GNU Emacs is distributed in the hope that it will be useful,
|
|
|
|
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
;; GNU General Public License for more details.
|
2004-09-04 13:13:48 +00:00
|
|
|
|
|
|
|
;; You should have received a copy of the GNU General Public License
|
2008-05-06 03:56:49 +00:00
|
|
|
;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
|
2004-09-04 13:13:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
;;; Commentary:
|
|
|
|
|
|
|
|
;; Contents management by FCM version 0.1.
|
|
|
|
|
|
|
|
;; Description:
|
|
|
|
;; ===========
|
|
|
|
|
2007-05-10 18:44:49 +00:00
|
|
|
;; gnus-diary is a utility toolkit used on top of the nndiary back end. It is
|
|
|
|
;; now fully documented in the Gnus manual.
|
2004-09-04 13:13:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
;; Bugs / Todo:
|
|
|
|
;; ===========
|
|
|
|
|
|
|
|
|
|
|
|
;;; Code:
|
|
|
|
|
|
|
|
(require 'nndiary)
|
|
|
|
(require 'message)
|
|
|
|
(require 'gnus-art)
|
|
|
|
|
|
|
|
(defgroup gnus-diary nil
|
2007-05-10 18:44:49 +00:00
|
|
|
"Utilities on top of the nndiary back end for Gnus."
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-324
Merge from gnus--rel--5.10
Patches applied:
* gnus--rel--5.10 (patch 70)
- Update from CVS
2005-05-17 Katsumi Yamaoka <yamaoka@jpl.org>
* lisp/gnus/canlock.el (canlock): Change the parent group to news.
* lisp/gnus/deuglify.el (gnus-outlook-deuglify): Add :group.
* lisp/gnus/dig.el (dig): Add :group.
* lisp/gnus/gnus-art.el (gnus-inhibit-mime-unbuttonizing): Add :group.
* lisp/gnus/gnus-cite.el (gnus-cite-attribution-face): Add :group.
(gnus-cite-face-1, gnus-cite-face-2, gnus-cite-face-3): Ditto.
(gnus-cite-face-4, gnus-cite-face-5, gnus-cite-face-6): Ditto.
(gnus-cite-face-7, gnus-cite-face-8, gnus-cite-face-9): Ditto.
(gnus-cite-face-10, gnus-cite-face-11): Ditto.
* lisp/gnus/gnus-diary.el (gnus-diary): Add :group.
* lisp/gnus/gnus.el (gnus-group-news-1-face): Add :group.
(gnus-group-news-1-empty-face): Ditto.
(gnus-group-news-2-face, gnus-group-news-2-empty-face): Ditto.
(gnus-group-news-3-face, gnus-group-news-3-empty-face): Ditto.
(gnus-group-news-4-face, gnus-group-news-4-empty-face): Ditto.
(gnus-group-news-5-face, gnus-group-news-5-empty-face): Ditto.
(gnus-group-news-6-face, gnus-group-news-6-empty-face): Ditto.
(gnus-group-news-low-face, gnus-group-news-low-empty-face): Ditto.
(gnus-group-mail-1-face, gnus-group-mail-1-empty-face): Ditto.
(gnus-group-mail-2-face, gnus-group-mail-2-empty-face): Ditto.
(gnus-group-mail-3-face, gnus-group-mail-3-empty-face): Ditto.
(gnus-group-mail-low-face, gnus-group-mail-low-empty-face): Ditto.
(gnus-summary-selected-face, gnus-summary-cancelled-face): Ditto.
(gnus-summary-high-ticked-face): Ditto.
(gnus-summary-low-ticked-face): Ditto.
(gnus-summary-normal-ticked-face): Ditto.
(gnus-summary-high-ancient-face): Ditto.
(gnus-summary-low-ancient-face): Ditto.
(gnus-summary-normal-ancient-face): Ditto.
(gnus-summary-high-undownloaded-face): Ditto.
(gnus-summary-low-undownloaded-face): Ditto.
(gnus-summary-normal-undownloaded-face): Ditto.
(gnus-summary-high-unread-face): Ditto.
(gnus-summary-low-unread-face): Ditto.
(gnus-summary-normal-unread-face): Ditto.
(gnus-summary-high-read-face, gnus-summary-low-read-face): Diito
(gnus-summary-normal-read-face, gnus-splash-face): Ditto.
* lisp/gnus/message.el (message-minibuffer-local-map): Add :group.
* lisp/gnus/sieve-manage.el (sieve-manage-log): Add :group.
(sieve-manage-default-user): Diito.
(sieve-manage-server-eol, sieve-manage-client-eol): Ditto.
(sieve-manage-streams, sieve-manage-stream-alist): Ditto.
(sieve-manage-authenticators): Ditto.
(sieve-manage-authenticator-alist): Ditto
(sieve-manage-default-port): Ditto.
* lisp/gnus/sieve-mode.el (sieve-control-commands-face): Add :group.
(sieve-action-commands-face): Ditto.
(sieve-test-commands-face): Ditto.
(sieve-tagged-arguments-face): Ditto.
* lisp/gnus/smime.el (smime): Add :group.
* lisp/gnus/spam-report.el (spam-report): Add :group.
* lisp/gnus/spam.el (spam, spam-face): Add :group.
2005-05-26 15:03:29 +00:00
|
|
|
:version "22.1"
|
|
|
|
:group 'gnus)
|
2004-09-04 13:13:48 +00:00
|
|
|
|
|
|
|
(defcustom gnus-diary-summary-line-format "%U%R%z %uD: %(%s%) (%ud)\n"
|
|
|
|
"*Summary line format for nndiary groups."
|
|
|
|
:type 'string
|
|
|
|
:group 'gnus-diary
|
|
|
|
:group 'gnus-summary-format)
|
|
|
|
|
|
|
|
(defcustom gnus-diary-time-format "%a, %b %e %y, %H:%M"
|
2007-06-06 23:51:11 +00:00
|
|
|
"*Time format to display appointments in nndiary summary buffers.
|
2004-09-04 13:13:48 +00:00
|
|
|
Please refer to `format-time-string' for information on possible values."
|
|
|
|
:type 'string
|
|
|
|
:group 'gnus-diary)
|
|
|
|
|
|
|
|
(defcustom gnus-diary-delay-format-function 'gnus-diary-delay-format-english
|
|
|
|
"*Function called to format a diary delay string.
|
2006-11-03 14:32:22 +00:00
|
|
|
It is passed two arguments. The first one is non-nil if the delay is in
|
2004-09-04 13:13:48 +00:00
|
|
|
the past. The second one is of the form ((NUM . UNIT) ...) where NUM is
|
|
|
|
an integer and UNIT is one of 'year 'month 'week 'day 'hour or 'minute.
|
|
|
|
It should return strings like \"In 2 months, 3 weeks\", \"3 hours,
|
|
|
|
1 minute ago\" and so on.
|
|
|
|
|
|
|
|
There are currently two built-in format functions:
|
|
|
|
`gnus-diary-delay-format-english' (the default)
|
|
|
|
`gnus-diary-delay-format-french'"
|
|
|
|
:type '(choice (const :tag "english" gnus-diary-delay-format-english)
|
|
|
|
(const :tag "french" gnus-diary-delay-format-french)
|
|
|
|
(symbol :tag "other"))
|
|
|
|
:group 'gnus-diary)
|
|
|
|
|
|
|
|
(defconst gnus-diary-version nndiary-version
|
2007-05-10 18:44:49 +00:00
|
|
|
"Current Diary back end version.")
|
2004-09-04 13:13:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
;; Compatibility functions ==================================================
|
|
|
|
|
2016-02-13 05:52:47 +00:00
|
|
|
(defun gnus-diary-kill-entire-line ()
|
|
|
|
(beginning-of-line)
|
|
|
|
(let ((kill-whole-line t))
|
|
|
|
(kill-line)))
|
2004-09-04 13:13:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
;; Summary line format ======================================================
|
|
|
|
|
|
|
|
(defun gnus-diary-delay-format-french (past delay)
|
|
|
|
(if (null delay)
|
|
|
|
"maintenant!"
|
|
|
|
;; Keep only a precision of two degrees
|
|
|
|
(and (> (length delay) 1) (setcdr (cdr delay) nil))
|
|
|
|
(concat (if past "il y a " "dans ")
|
|
|
|
(let ((str "")
|
|
|
|
del)
|
|
|
|
(while (setq del (pop delay))
|
|
|
|
(setq str (concat str
|
|
|
|
(int-to-string (car del)) " "
|
|
|
|
(cond ((eq (cdr del) 'year)
|
|
|
|
"an")
|
|
|
|
((eq (cdr del) 'month)
|
|
|
|
"mois")
|
|
|
|
((eq (cdr del) 'week)
|
|
|
|
"semaine")
|
|
|
|
((eq (cdr del) 'day)
|
|
|
|
"jour")
|
|
|
|
((eq (cdr del) 'hour)
|
|
|
|
"heure")
|
|
|
|
((eq (cdr del) 'minute)
|
|
|
|
"minute"))
|
|
|
|
(unless (or (eq (cdr del) 'month)
|
|
|
|
(= (car del) 1))
|
|
|
|
"s")
|
|
|
|
(if delay ", "))))
|
|
|
|
str))))
|
|
|
|
|
|
|
|
|
|
|
|
(defun gnus-diary-delay-format-english (past delay)
|
|
|
|
(if (null delay)
|
|
|
|
"now!"
|
|
|
|
;; Keep only a precision of two degrees
|
|
|
|
(and (> (length delay) 1) (setcdr (cdr delay) nil))
|
|
|
|
(concat (unless past "in ")
|
|
|
|
(let ((str "")
|
|
|
|
del)
|
|
|
|
(while (setq del (pop delay))
|
|
|
|
(setq str (concat str
|
|
|
|
(int-to-string (car del)) " "
|
|
|
|
(symbol-name (cdr del))
|
|
|
|
(and (> (car del) 1) "s")
|
|
|
|
(if delay ", "))))
|
|
|
|
str)
|
|
|
|
(and past " ago"))))
|
|
|
|
|
|
|
|
|
|
|
|
(defun gnus-diary-header-schedule (headers)
|
|
|
|
;; Same as `nndiary-schedule', but given a set of headers HEADERS
|
|
|
|
(mapcar
|
|
|
|
(lambda (elt)
|
|
|
|
(let ((head (cdr (assoc (intern (format "X-Diary-%s" (car elt)))
|
|
|
|
headers))))
|
|
|
|
(when head
|
2004-09-29 06:35:14 +00:00
|
|
|
(nndiary-parse-schedule-value head (cadr elt) (car (cddr elt))))))
|
2004-09-04 13:13:48 +00:00
|
|
|
nndiary-headers))
|
|
|
|
|
|
|
|
;; #### NOTE: Gnus sometimes gives me a HEADER not corresponding to any
|
|
|
|
;; message, with all fields set to nil here. I don't know what it is for, and
|
|
|
|
;; I just ignore it.
|
2006-06-29 22:54:24 +00:00
|
|
|
;;;###autoload
|
2004-09-04 13:13:48 +00:00
|
|
|
(defun gnus-user-format-function-d (header)
|
2011-11-14 23:59:56 +00:00
|
|
|
;; Return an approximate delay string for the next occurrence of this
|
2004-09-04 13:13:48 +00:00
|
|
|
;; message. The delay is given only in the first non zero unit.
|
|
|
|
;; Code partly stolen from article-make-date-line
|
|
|
|
(let* ((extras (mail-header-extra header))
|
|
|
|
(sched (gnus-diary-header-schedule extras))
|
|
|
|
(occur (nndiary-next-occurence sched (current-time)))
|
|
|
|
(now (current-time))
|
Simplify now that float-time etc. are built-in
This was prompted by warnings about calls to now-obsolete functions.
* lisp/calendar/time-date.el (encode-time-value):
Use setq rather than a recursive call, to avoid a warning
about calling this obsolete function.
* lisp/calendar/time-date.el (encode-time-value)
(with-decoded-time-value, time-to-seconds, time-to-number-of-days):
* lisp/erc/erc.el (erc-emacs-time-to-erc-time):
* lisp/net/rcirc.el (rcirc-float-time):
* lisp/org/org-compat.el (org-float-time):
Simplify now that time-add and float-time are now built-in.
* lisp/calendar/time-date.el (time-add, time-subtract, time-less-p):
* lisp/net/newst-backend.el (time-add):
* lisp/org/org.el (time-subtract):
Remove backward-compatibility definitions; they are now built-in.
* lisp/calendar/timeclock.el (timeclock-time-to-seconds)
(timeclock-seconds-to-time):
* lisp/net/rcirc.el (rcirc-float-time):
* lisp/org/org-compat.el (org-float-time):
Now obsolete, since callers can just use float-time and
seconds-to-time. All uses changed.
* lisp/emacs-lisp/ert.el (ert-results-pop-to-timings):
* lisp/gnus/gnus-art.el (article-lapsed-string):
* lisp/gnus/gnus-diary.el (gnus-user-format-function-d):
* lisp/gnus/gnus-group.el (gnus-group-timestamp-delta):
* lisp/gnus/nndiary.el (nndiary-compute-reminders):
* lisp/net/tramp.el (tramp-time-diff):
* lisp/org/org-clock.el (org-clock-timestamps-change):
Prefer the time-subtract builtin to the subtract-time alias.
* lisp/files.el (dir-locals-find-file, dir-locals-read-from-dir):
* test/lisp/character-fold-tests.el (character-fold--speed-test):
Prefer the float-time builtin to the time-to-seconds alias.
* lisp/org/org-agenda.el, lisp/org/org-clock.el, lisp/org/org-list.el:
* lisp/org/org-timer.el, lisp/org/org.el:
Adjust to org-float-time deprecation.
2016-05-08 19:46:00 +00:00
|
|
|
(real-time (time-subtract occur now)))
|
2004-09-04 13:13:48 +00:00
|
|
|
(if (null real-time)
|
|
|
|
"?????"
|
|
|
|
(let* ((sec (+ (* (float (car real-time)) 65536) (cadr real-time)))
|
|
|
|
(past (< sec 0))
|
|
|
|
delay)
|
|
|
|
(and past (setq sec (- sec)))
|
|
|
|
(unless (zerop sec)
|
|
|
|
;; This is a bit convoluted, but basically we go through the time
|
|
|
|
;; units for years, weeks, etc, and divide things to see whether
|
|
|
|
;; that results in positive answers.
|
|
|
|
(let ((units `((year . ,(* 365.25 24 3600))
|
|
|
|
(month . ,(* 31 24 3600))
|
|
|
|
(week . ,(* 7 24 3600))
|
|
|
|
(day . ,(* 24 3600))
|
|
|
|
(hour . 3600)
|
|
|
|
(minute . 60)))
|
|
|
|
unit num)
|
|
|
|
(while (setq unit (pop units))
|
|
|
|
(unless (zerop (setq num (ffloor (/ sec (cdr unit)))))
|
|
|
|
(setq delay (append delay `((,(floor num) . ,(car unit))))))
|
|
|
|
(setq sec (- sec (* num (cdr unit)))))))
|
|
|
|
(funcall gnus-diary-delay-format-function past delay)))
|
|
|
|
))
|
|
|
|
|
|
|
|
;; #### NOTE: Gnus sometimes gives me a HEADER not corresponding to any
|
|
|
|
;; message, with all fields set to nil here. I don't know what it is for, and
|
|
|
|
;; I just ignore it.
|
2006-06-29 22:54:24 +00:00
|
|
|
;;;###autoload
|
2004-09-04 13:13:48 +00:00
|
|
|
(defun gnus-user-format-function-D (header)
|
2010-01-14 18:37:23 +00:00
|
|
|
;; Returns a formatted time string for the next occurrence of this message.
|
2004-09-04 13:13:48 +00:00
|
|
|
(let* ((extras (mail-header-extra header))
|
|
|
|
(sched (gnus-diary-header-schedule extras))
|
|
|
|
(occur (nndiary-next-occurence sched (current-time))))
|
|
|
|
(format-time-string gnus-diary-time-format occur)))
|
|
|
|
|
|
|
|
|
|
|
|
;; Article sorting functions ================================================
|
|
|
|
|
|
|
|
(defun gnus-article-sort-by-schedule (h1 h2)
|
|
|
|
(let* ((now (current-time))
|
|
|
|
(e1 (mail-header-extra h1))
|
|
|
|
(e2 (mail-header-extra h2))
|
|
|
|
(s1 (gnus-diary-header-schedule e1))
|
|
|
|
(s2 (gnus-diary-header-schedule e2))
|
|
|
|
(o1 (nndiary-next-occurence s1 now))
|
|
|
|
(o2 (nndiary-next-occurence s2 now)))
|
|
|
|
(if (and (= (car o1) (car o2)) (= (cadr o1) (cadr o2)))
|
|
|
|
(< (mail-header-number h1) (mail-header-number h2))
|
|
|
|
(time-less-p o1 o2))))
|
|
|
|
|
|
|
|
|
|
|
|
(defun gnus-thread-sort-by-schedule (h1 h2)
|
|
|
|
(gnus-article-sort-by-schedule (gnus-thread-header h1)
|
|
|
|
(gnus-thread-header h2)))
|
|
|
|
|
|
|
|
(defun gnus-summary-sort-by-schedule (&optional reverse)
|
2007-06-06 23:51:11 +00:00
|
|
|
"Sort nndiary summary buffers by schedule of appointments.
|
2004-09-04 13:13:48 +00:00
|
|
|
Optional prefix (or REVERSE argument) means sort in reverse order."
|
|
|
|
(interactive "P")
|
|
|
|
(gnus-summary-sort 'schedule reverse))
|
|
|
|
|
|
|
|
(defvar gnus-summary-misc-menu) ;; Avoid byte compiler warning.
|
|
|
|
(add-hook 'gnus-summary-menu-hook
|
|
|
|
(lambda ()
|
|
|
|
(easy-menu-add-item gnus-summary-misc-menu
|
|
|
|
'("Sort")
|
|
|
|
["Sort by schedule"
|
|
|
|
gnus-summary-sort-by-schedule
|
|
|
|
(eq (car (gnus-find-method-for-group
|
|
|
|
gnus-newsgroup-name))
|
|
|
|
'nndiary)]
|
|
|
|
"Sort by number")))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
;; Group parameters autosetting =============================================
|
|
|
|
|
|
|
|
(defun gnus-diary-update-group-parameters (group)
|
|
|
|
;; Ensure that nndiary groups have convenient group parameters:
|
|
|
|
;; - a posting style containing X-Diary headers
|
|
|
|
;; - a nice summary line format
|
|
|
|
;; - NNDiary specific sorting by schedule functions
|
|
|
|
;; In general, try not to mess with what the user might have modified.
|
2007-10-28 09:18:39 +00:00
|
|
|
|
|
|
|
;; Posting style:
|
|
|
|
(let ((posting-style (gnus-group-get-parameter group 'posting-style t))
|
|
|
|
(headers nndiary-headers)
|
|
|
|
header)
|
|
|
|
(while headers
|
|
|
|
(setq header (format "X-Diary-%s" (caar headers))
|
|
|
|
headers (cdr headers))
|
|
|
|
(unless (assoc header posting-style)
|
|
|
|
(setq posting-style (append posting-style (list (list header "*"))))))
|
|
|
|
(gnus-group-set-parameter group 'posting-style posting-style))
|
|
|
|
;; Summary line format:
|
|
|
|
(unless (gnus-group-get-parameter group 'gnus-summary-line-format t)
|
|
|
|
(gnus-group-set-parameter group 'gnus-summary-line-format
|
|
|
|
`(,gnus-diary-summary-line-format)))
|
|
|
|
;; Sorting by schedule:
|
|
|
|
(unless (gnus-group-get-parameter group 'gnus-article-sort-functions)
|
|
|
|
(gnus-group-set-parameter group 'gnus-article-sort-functions
|
|
|
|
'((append gnus-article-sort-functions
|
|
|
|
(list
|
|
|
|
'gnus-article-sort-by-schedule)))))
|
|
|
|
(unless (gnus-group-get-parameter group 'gnus-thread-sort-functions)
|
|
|
|
(gnus-group-set-parameter group 'gnus-thread-sort-functions
|
|
|
|
'((append gnus-thread-sort-functions
|
|
|
|
(list
|
|
|
|
'gnus-thread-sort-by-schedule))))))
|
2004-09-04 13:13:48 +00:00
|
|
|
|
|
|
|
;; Called when a group is subscribed. This is needed because groups created
|
2007-05-10 18:44:49 +00:00
|
|
|
;; because of mail splitting are *not* created with the back end function.
|
2012-11-13 03:11:46 +00:00
|
|
|
;; Thus, `nndiary-request-create-group-functions' is inoperative.
|
2004-09-04 13:13:48 +00:00
|
|
|
(defun gnus-diary-maybe-update-group-parameters (group)
|
|
|
|
(when (eq (car (gnus-find-method-for-group group)) 'nndiary)
|
|
|
|
(gnus-diary-update-group-parameters group)))
|
|
|
|
|
2012-11-13 03:11:46 +00:00
|
|
|
(add-hook 'nndiary-request-create-group-functions
|
2004-09-04 13:13:48 +00:00
|
|
|
'gnus-diary-update-group-parameters)
|
2012-11-13 03:11:46 +00:00
|
|
|
;; Now that we have `gnus-subscribe-newsgroup-functions', this is not needed
|
2004-09-04 13:13:48 +00:00
|
|
|
;; anymore. Maybe I should remove this completely.
|
2012-11-13 03:11:46 +00:00
|
|
|
(add-hook 'nndiary-request-update-info-functions
|
2004-09-04 13:13:48 +00:00
|
|
|
'gnus-diary-update-group-parameters)
|
2012-11-13 03:11:46 +00:00
|
|
|
(add-hook 'gnus-subscribe-newsgroup-functions
|
2004-09-04 13:13:48 +00:00
|
|
|
'gnus-diary-maybe-update-group-parameters)
|
|
|
|
|
|
|
|
|
|
|
|
;; Diary Message Checking ===================================================
|
|
|
|
|
|
|
|
(defvar gnus-diary-header-value-history nil
|
|
|
|
;; History variable for header value prompting
|
|
|
|
)
|
|
|
|
|
|
|
|
(defun gnus-diary-narrow-to-headers ()
|
|
|
|
"Narrow the current buffer to the header part.
|
|
|
|
Point is left at the beginning of the region.
|
|
|
|
The buffer is assumed to contain a message, but the format is unknown."
|
|
|
|
(cond ((eq major-mode 'message-mode)
|
|
|
|
(message-narrow-to-headers))
|
|
|
|
(t
|
|
|
|
(goto-char (point-min))
|
|
|
|
(when (search-forward "\n\n" nil t)
|
|
|
|
(narrow-to-region (point-min) (- (point) 1))
|
|
|
|
(goto-char (point-min))))
|
|
|
|
))
|
|
|
|
|
|
|
|
(defun gnus-diary-add-header (str)
|
|
|
|
"Add a header to the current buffer.
|
|
|
|
The buffer is assumed to contain a message, but the format is unknown."
|
|
|
|
(cond ((eq major-mode 'message-mode)
|
|
|
|
(message-add-header str))
|
|
|
|
(t
|
|
|
|
(save-restriction
|
|
|
|
(gnus-diary-narrow-to-headers)
|
|
|
|
(goto-char (point-max))
|
|
|
|
(if (string-match "\n$" str)
|
|
|
|
(insert str)
|
|
|
|
(insert str ?\n))))
|
|
|
|
))
|
|
|
|
|
|
|
|
(defun gnus-diary-check-message (arg)
|
|
|
|
"Ensure that the current message is a valid for NNDiary.
|
|
|
|
This function checks that all NNDiary required headers are present and
|
|
|
|
valid, and prompts for values / correction otherwise.
|
|
|
|
|
|
|
|
If ARG (or prefix) is non-nil, force prompting for all fields."
|
|
|
|
(interactive "P")
|
|
|
|
(save-excursion
|
|
|
|
(mapcar
|
|
|
|
(lambda (head)
|
|
|
|
(let ((header (concat "X-Diary-" (car head)))
|
|
|
|
(ask arg)
|
|
|
|
value invalid)
|
|
|
|
;; First, try to find the header, and checks for validity:
|
|
|
|
(save-restriction
|
|
|
|
(gnus-diary-narrow-to-headers)
|
|
|
|
(when (re-search-forward (concat "^" header ":") nil t)
|
|
|
|
(unless (eq (char-after) ? )
|
|
|
|
(insert " "))
|
2007-10-28 09:18:39 +00:00
|
|
|
(setq value (buffer-substring (point) (point-at-eol)))
|
2004-09-04 13:13:48 +00:00
|
|
|
(and (string-match "[ \t]*\\([^ \t]+\\)[ \t]*" value)
|
|
|
|
(setq value (match-string 1 value)))
|
|
|
|
(condition-case ()
|
|
|
|
(nndiary-parse-schedule-value value
|
|
|
|
(nth 1 head) (nth 2 head))
|
2009-09-18 07:39:56 +00:00
|
|
|
(error
|
2004-09-04 13:13:48 +00:00
|
|
|
(setq invalid t)))
|
|
|
|
;; #### NOTE: this (along with the `gnus-diary-add-header'
|
|
|
|
;; function) could be rewritten in a better way, in particular
|
|
|
|
;; not to blindly remove an already present header and reinsert
|
|
|
|
;; it somewhere else afterwards.
|
|
|
|
(when (or ask invalid)
|
|
|
|
(gnus-diary-kill-entire-line))
|
|
|
|
))
|
|
|
|
;; Now, loop until a valid value is provided:
|
|
|
|
(while (or ask (not value) invalid)
|
|
|
|
(let ((prompt (concat (and invalid
|
|
|
|
(prog1 "(current value invalid) "
|
|
|
|
(beep)))
|
|
|
|
header ": ")))
|
|
|
|
(setq value
|
|
|
|
(if (listp (nth 1 head))
|
2010-10-16 01:55:08 +00:00
|
|
|
(gnus-completing-read prompt (cons "*" (mapcar 'car (nth 1 head)))
|
Merge changes made in Gnus trunk.
nndraft.el (nndraft-request-expire-articles): Use the group name instead if "nndraft".
gnus.texi (Using IMAP): Remove the @acronyms from the headings.
nnregistry.el: Added.
nnimap.el (nnimap-insert-partial-structure): Be way more permissive when interpreting the structures.
GNUS-NEWS: Minor error in GNUS-NEWS - password-cache.el.
nnimap.el (nnimap-request-accept-article): Add \r\n to the lines to make this work with Cyrus.
gnus-registry.el: Don't prompt on load, which makes it impossible to build Gnus.
gnus-gravatar.el: Add gnus-gravatar-properties.
gnus-agent.el, gnus-art.el, gnus-bookmark.el, gnus-dired.el, gnus-group.el,\
gnus-int.el, gnus-msg.el, gnus-registry.el, gnus-score.el, gnus-srvr.el,\
gnus-sum.el, gnus-topic.el, gnus-util.el, gnus.el, mm-decode.el, mm-util.el,\
mm-view.el, mml-smime.el, mml.el, nnmairix.el, nnrss.el, smime.el:\
Introduce gnus-completing-read.
gnus-util.el: Make completing-read function configurable.
gnus-util.el: Add requires and fix history for iswitchb.
webmail.el: Remove netscape/my-deja, since they no longer exist.
gnus.el (gnus-local-domain): Declare variable obsolete.
nnimap.el (nnimap-insert-partial-structure): Get the type from the correct slot, too.
pop3.el (pop3-send-streaming-command, pop3-stream-length): New variable.
nnimap.el (nnimap-open-connection): Revert the auto-network->starttls code.
nnimap.el (nnimap-request-set-mark): Erase the buffer before issuing commands.
nnimap.el (nnimap-split-rule): Mark as obsolete.
gnus-sum.el (gnus-valid-move-group-p): Make sure that `group' is a symbol.
nnimap.el (nnimap-split-incoming-mail): Allow `default' as nnimap-split-methods value.
nnimap.el (nnimap-request-article): Downcase the NILs so that they are nil.
nndoc.el (nndoc-retrieve-groups): New function.
gnus.texi: Fix Gravatar documentation.
2010-09-30 08:39:23 +00:00
|
|
|
t value
|
|
|
|
'gnus-diary-header-value-history)
|
2004-09-04 13:13:48 +00:00
|
|
|
(read-string prompt value
|
Merge changes made in Gnus trunk.
nndraft.el (nndraft-request-expire-articles): Use the group name instead if "nndraft".
gnus.texi (Using IMAP): Remove the @acronyms from the headings.
nnregistry.el: Added.
nnimap.el (nnimap-insert-partial-structure): Be way more permissive when interpreting the structures.
GNUS-NEWS: Minor error in GNUS-NEWS - password-cache.el.
nnimap.el (nnimap-request-accept-article): Add \r\n to the lines to make this work with Cyrus.
gnus-registry.el: Don't prompt on load, which makes it impossible to build Gnus.
gnus-gravatar.el: Add gnus-gravatar-properties.
gnus-agent.el, gnus-art.el, gnus-bookmark.el, gnus-dired.el, gnus-group.el,\
gnus-int.el, gnus-msg.el, gnus-registry.el, gnus-score.el, gnus-srvr.el,\
gnus-sum.el, gnus-topic.el, gnus-util.el, gnus.el, mm-decode.el, mm-util.el,\
mm-view.el, mml-smime.el, mml.el, nnmairix.el, nnrss.el, smime.el:\
Introduce gnus-completing-read.
gnus-util.el: Make completing-read function configurable.
gnus-util.el: Add requires and fix history for iswitchb.
webmail.el: Remove netscape/my-deja, since they no longer exist.
gnus.el (gnus-local-domain): Declare variable obsolete.
nnimap.el (nnimap-insert-partial-structure): Get the type from the correct slot, too.
pop3.el (pop3-send-streaming-command, pop3-stream-length): New variable.
nnimap.el (nnimap-open-connection): Revert the auto-network->starttls code.
nnimap.el (nnimap-request-set-mark): Erase the buffer before issuing commands.
nnimap.el (nnimap-split-rule): Mark as obsolete.
gnus-sum.el (gnus-valid-move-group-p): Make sure that `group' is a symbol.
nnimap.el (nnimap-split-incoming-mail): Allow `default' as nnimap-split-methods value.
nnimap.el (nnimap-request-article): Downcase the NILs so that they are nil.
nndoc.el (nndoc-retrieve-groups): New function.
gnus.texi: Fix Gravatar documentation.
2010-09-30 08:39:23 +00:00
|
|
|
'gnus-diary-header-value-history))))
|
2004-09-04 13:13:48 +00:00
|
|
|
(setq ask nil)
|
|
|
|
(setq invalid nil)
|
|
|
|
(condition-case ()
|
|
|
|
(nndiary-parse-schedule-value value
|
|
|
|
(nth 1 head) (nth 2 head))
|
2009-09-18 07:39:56 +00:00
|
|
|
(error
|
2004-09-04 13:13:48 +00:00
|
|
|
(setq invalid t))))
|
|
|
|
(gnus-diary-add-header (concat header ": " value))
|
|
|
|
))
|
|
|
|
nndiary-headers)
|
|
|
|
))
|
|
|
|
|
2012-11-13 03:11:46 +00:00
|
|
|
(add-hook 'nndiary-request-accept-article-functions
|
2004-09-04 13:13:48 +00:00
|
|
|
(lambda () (gnus-diary-check-message nil)))
|
|
|
|
|
2008-04-21 07:13:33 +00:00
|
|
|
(define-key message-mode-map "\C-c\C-fd" 'gnus-diary-check-message)
|
|
|
|
(define-key gnus-article-edit-mode-map "\C-c\C-fd" 'gnus-diary-check-message)
|
2004-09-04 13:13:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
;; The end ==================================================================
|
|
|
|
|
|
|
|
(defun gnus-diary-version ()
|
2007-05-10 18:44:49 +00:00
|
|
|
"Current Diary back end version."
|
2004-09-04 13:13:48 +00:00
|
|
|
(interactive)
|
|
|
|
(message "NNDiary version %s" nndiary-version))
|
|
|
|
|
|
|
|
(provide 'gnus-diary)
|
|
|
|
|
|
|
|
;;; gnus-diary.el ends here
|