Fix bug related to agenda bulding with hour repeaters

* lisp/org.el: Make `org-closest-date' aware of hours repeaters.
This commit is contained in:
Nicolas Goaziou 2012-10-10 16:11:41 +02:00
parent 8f96754932
commit 92199873c5

View file

@ -16156,7 +16156,12 @@ When PREFER is `future', return a date that is either CURRENT or future.
When SHOW-ALL is nil, only return the current occurrence of a time stamp."
;; Make the proper lists from the dates
(catch 'exit
(let ((a1 '(("d" . day) ("w" . week) ("m" . month) ("y" . year)))
(let ((a1 '(("h" . hour)
("d" . day)
("w" . week)
("m" . month)
("y" . year)))
(shour (nth 2 (org-parse-time-string start)))
dn dw sday cday n1 n2 n0
d m y y1 y2 date1 date2 nmonths nm ny m2)
@ -16176,6 +16181,13 @@ When SHOW-ALL is nil, only return the current occurrence of a time stamp."
(error "Invalid change specifier: %s" change))
(if (eq dw 'week) (setq dw 'day dn (* 7 dn)))
(cond
((eq dw 'hour)
(let ((missing-hours
(mod (+ (- (* 24 (- cday sday)) shour) org-extend-today-until)
dn)))
(setq n1 (if (zerop missing-hours) cday
(- cday (1+ (floor (/ missing-hours 24)))))
n2 (+ cday (floor (/ (- dn missing-hours) 24))))))
((eq dw 'day)
(setq n1 (+ sday (* dn (floor (/ (- cday sday) dn))))
n2 (+ n1 dn)))