emacs-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[appt] allow specifying warning time in diary


From: Leo
Subject: [appt] allow specifying warning time in diary
Date: Wed, 08 Sep 2010 09:54:31 +0100
User-agent: Gnus/5.13 (Gnus v5.13) Emacs/23.2 (Mac OS X 10.6.4)

Hello,

When I put an appointment in the diary, sometimes I also want to set an
alert time. For example, if I am meeting a friend in London, I need a
notice 3 hours before the appointment.

The attached patch allows inserting in the diary something like this:

Saturday
        13:00 #180 Lunch with Theresa.

Is this feature useful?

Leo

        Modified lisp/calendar/appt.el
diff --git a/lisp/calendar/appt.el b/lisp/calendar/appt.el
index 15a9d54..e70644c 100644
--- a/lisp/calendar/appt.el
+++ b/lisp/calendar/appt.el
@@ -273,6 +273,12 @@ for a warning to be issued.  The format of the time can be 
either
               Thursday
                 11:45am Lunch meeting.
 
+Optionally you can specify a warning time for an entry following
+the time. For example:
+
+              Thursday
+                11:45am #20 Lunch meeting.
+
 Appointments are checked every `appt-display-interval' minutes.
 The following variables control appointment notification:
 
@@ -579,7 +585,8 @@ appointment package (if it is not already active)."
                              (calendar-current-date) (caar entry-list)))
                   (setq time-string (cadr (car entry-list)))
                   (while (string-match appt-time-regexp time-string)
-                    (let* ((beg (match-beginning 0))
+                    (let* ((time-beg (match-beginning 0))
+                           (time-end (match-end 0))
                            ;; Get just the time for this appointment.
                            (only-time (match-string 0 time-string))
                            ;; Find the end of this appointment
@@ -590,9 +597,20 @@ appointment package (if it is not already active)."
                                  (match-end 0)))
                            ;; Get the whole string for this appointment.
                            (appt-time-string
-                            (substring time-string beg end))
+                            (substring time-string time-beg end))
+                           (warntime
+                            (when (and (string-match
+                                        "[ \t]*#\\([-+]?[0-9]+\\)[ \t]*"
+                                        appt-time-string time-end)
+                                       (= (match-beginning 0) time-end))
+                              (prog1 (string-to-number
+                                      (match-string 1 appt-time-string))
+                                (setq appt-time-string
+                                      (replace-match " " nil nil
+                                                     appt-time-string)))))
                            (appt-time (list (appt-convert-time only-time)))
-                           (time-msg (list appt-time appt-time-string)))
+                           (time-msg (list appt-time appt-time-string
+                                           nil warntime)))
                       ;; Add this appointment to appt-time-msg-list.
                       (setq appt-time-msg-list
                             (nconc appt-time-msg-list (list time-msg))





reply via email to

[Prev in Thread] Current Thread [Next in Thread]