]> git.eshelyaron.com Git - emacs.git/commitdiff
(increment-calendar-month): Optionally handle systems without 12
authorGlenn Morris <rgm@gnu.org>
Mon, 31 Mar 2008 16:00:05 +0000 (16:00 +0000)
committerGlenn Morris <rgm@gnu.org>
Mon, 31 Mar 2008 16:00:05 +0000 (16:00 +0000)
months per year.

lisp/ChangeLog
lisp/calendar/calendar.el

index 4ce645dbbaaf66c812fb3312db29c43675014d9f..60992a89e436704de63dbf3946debb5555445498 100644 (file)
@@ -49,7 +49,9 @@
        * calendar/cal-julian.el (holiday-julian): Fix a problem with holidays
        in the last fortnight in Julian October.
 
-       * calendar/calendar.el (increment-calendar-month): Doc fix.
+       * calendar/calendar.el (increment-calendar-month): Optionally handle
+       systems without 12 months per year.
+
        (calendar-date-is-visible-p): Doc fix.  Simplify.
 
        * calendar/holidays.el (holiday-filter-visible-calendar): Return result
index cd39f1ebbac913721ab4fe133307d6aea9198a16..46f0bcd350aff879fc39483a743e8898509bc14f 100644 (file)
@@ -1213,20 +1213,23 @@ with descriptive strings such as
 (defconst cal-hebrew-yahrzeit-buffer "*Yahrzeits*"
   "Name of the buffer used by `list-yahrzeit-dates'.")
 
-(defmacro increment-calendar-month (mon yr n)
+(defmacro increment-calendar-month (mon yr n &optional nmonths)
   "Increment the variables MON and YR by N months.
 Forward if N is positive or backward if N is negative.
 A negative YR is interpreted as BC; -1 being 1 BC, and so on.
-This is only appropriate for calendars with 12 months per year."
-  `(let (macro-y)
-     ;; FIXME 12 could be an optional arg, if needed.
+Optional NMONTHS is the number of months per year (default 12)."
+  ;; Can view this as a form of base-nmonths arithmetic, in which "a
+  ;; year" = "ten", and we never bother to use hundreds.
+  `(let ((nmonths (or ,nmonths 12))
+         macro-y)
      (if (< ,yr 0) (setq ,yr (1+ ,yr))) ; -1 BC -> 0 AD, etc
-     (setq macro-y (+ (* ,yr 12) ,mon -1 ,n)
-           ,mon (1+ (mod macro-y 12))
-           ,yr (/ macro-y 12))
-;;;      (setq macro-y (+ (* ,yr 12) ,mon -1 ,n)
-;;;            ,yr (/ macro-y 12)
-;;;            ,mon (- macro-y (* ,yr 12)))
+     (setq macro-y (+ (* ,yr nmonths) ,mon -1 ,n)
+           ,mon (1+ (mod macro-y nmonths))
+           ,yr (/ macro-y nmonths))
+     ;; Alternative:
+;;;      (setq macro-y (+ (* ,yr nmonths) ,mon -1 ,n)
+;;;            ,yr (/ macro-y nmonths)
+;;;            ,mon (- macro-y (* ,yr nmonths)))
      (and (< macro-y 0) (> ,mon 1) (setq ,yr (1- ,yr)))
      (if (< ,yr 1) (setq ,yr (1- ,yr))))) ; 0 AD -> -1 BC, etc