From 0d16be53d138979c88d56bf0812a7c6c237d0491 Mon Sep 17 00:00:00 2001 From: Glenn Morris Date: Mon, 31 Mar 2008 07:40:11 +0000 Subject: [PATCH] (holiday-chinese-new-year): Doc fix and comment. --- lisp/calendar/cal-china.el | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/lisp/calendar/cal-china.el b/lisp/calendar/cal-china.el index 544a09b2614..702fec9931a 100644 --- a/lisp/calendar/cal-china.el +++ b/lisp/calendar/cal-china.el @@ -421,19 +421,25 @@ Gregorian date Sunday, December 31, 1 BC." ;;;###holiday-autoload (defun holiday-chinese-new-year () - "Date of Chinese New Year." + "Date of Chinese New Year, if visible in calendar. +Returns (((MONTH DAY YEAR) TEXT)), where the date is Gregorian." (let ((m displayed-month) (y displayed-year)) - (increment-calendar-month m y 1) + ;; In the Gregorian calendar, CNY falls between Jan 21 and Feb 20. + ;; Jan is visible if displayed-month = 12, 1, 2; Feb if d-m = 1, 2, 3. + ;; If we shift the calendar forward one month, we can do a + ;; one-sided test, namely: d-m <= 4 means CNYN might be visible. + (increment-calendar-month m y 1) ; shift forward a month (if (< m 5) (let ((chinese-new-year (calendar-gregorian-from-absolute (cadr (assoc 1 (chinese-year y)))))) (if (calendar-date-is-visible-p chinese-new-year) - (list - (list chinese-new-year - (format "Chinese New Year (%s)" - (calendar-chinese-sexagesimal-name (+ y 57)))))))))) + (list + (list chinese-new-year + (format "Chinese New Year (%s)" + (calendar-chinese-sexagesimal-name + (+ y 57)))))))))) ;;;###cal-autoload (defun calendar-chinese-date-string (&optional date) -- 2.39.5