1
0
mirror of https://git.savannah.gnu.org/git/emacs.git synced 2025-01-21 18:23:59 +00:00

(calendar-mode-line-format): Change "current" to "today".

(calendar-cursor-to-date): Add optional parameter to cause error
signal when cursor is not on a date---this allows lots of
simplifications throughout the code.
(calendar-forward-month,calendar-set-mark,
calendar-exchange-point-and-mark,calendar-count-days-region,
calendar-print-day-of-year,calendar-print-iso-date,
calendar-print-julian-date,calendar-print-islamic-date,
calendar-print-hebrew-date,calendar-print-astro-day-number): Use simplification.
This commit is contained in:
Richard M. Stallman 1994-02-07 20:42:44 +00:00
parent d1462f221c
commit ffd82264f0

View File

@ -1539,7 +1539,7 @@ the inserted text. Value is always t."
(list (list
(substitute-command-keys "\\<calendar-mode-map>\\[scroll-calendar-left]") (substitute-command-keys "\\<calendar-mode-map>\\[scroll-calendar-left]")
"Calendar" "Calendar"
(substitute-command-keys "\\<calendar-mode-map>\\[describe-calendar-mode] help/\\[calendar-other-month] other/\\[calendar-current-month] current") (substitute-command-keys "\\<calendar-mode-map>\\[describe-calendar-mode] help/\\[calendar-other-month] other/\\[calendar-current-month] today")
'(calendar-date-string (calendar-current-date) t) '(calendar-date-string (calendar-current-date) t)
(substitute-command-keys "\\<calendar-mode-map>\\[scroll-calendar-right]")) (substitute-command-keys "\\<calendar-mode-map>\\[scroll-calendar-right]"))
"The mode line of the calendar buffer.") "The mode line of the calendar buffer.")
@ -1850,8 +1850,7 @@ concatenated and the result truncated."
Movement is backward if ARG is negative." Movement is backward if ARG is negative."
(interactive "p") (interactive "p")
(calendar-cursor-to-nearest-date) (calendar-cursor-to-nearest-date)
(let* ((cursor-date (or (calendar-cursor-to-date) (let* ((cursor-date (calendar-cursor-to-date t))
(error "Cursor is not on a date!")))
(month (extract-calendar-month cursor-date)) (month (extract-calendar-month cursor-date))
(day (extract-calendar-day cursor-date)) (day (extract-calendar-day cursor-date))
(year (extract-calendar-year cursor-date))) (year (extract-calendar-year cursor-date)))
@ -1943,9 +1942,10 @@ If in the calendar buffer, also sets the current date local variables."
(string-to-int (substring date (match-beginning 4) (match-end 4))))) (string-to-int (substring date (match-beginning 4) (match-end 4)))))
(list month day year))) (list month day year)))
(defun calendar-cursor-to-date () (defun calendar-cursor-to-date (&optional error)
"Returns a list of the month, day, and year of current cursor position. "Returns a list of the month, day, and year of current cursor position.
Returns nil if the cursor is not on a specific day." If cursor is not on a specific date, signals an error if optional parameter
ERROR is t, otherwise just returns nil."
(if (and (looking-at "[*0-9]") (if (and (looking-at "[*0-9]")
(< 2 (count-lines (point-min) (point)))) (< 2 (count-lines (point-min) (point))))
(save-excursion (save-excursion
@ -1962,7 +1962,8 @@ Returns nil if the cursor is not on a specific day."
((and (= 12 month) (= segment 0)) (1- displayed-year)) ((and (= 12 month) (= segment 0)) (1- displayed-year))
((and (= 1 month) (= segment 2)) (1+ displayed-year)) ((and (= 1 month) (= segment 2)) (1+ displayed-year))
(t displayed-year)))) (t displayed-year))))
(list month day year))))) (list month day year)))
(if error (error "Cursor is not on a date!"))))
(defun calendar-cursor-to-nearest-date () (defun calendar-cursor-to-nearest-date ()
"Move the cursor to the closest date. "Move the cursor to the closest date.
@ -2233,8 +2234,7 @@ Gregorian date Sunday, December 31, 1 BC."
With no prefix argument, push current date onto marked date ring. With no prefix argument, push current date onto marked date ring.
With argument, jump to mark, pop it, and put point at end of ring." With argument, jump to mark, pop it, and put point at end of ring."
(interactive "P") (interactive "P")
(let ((date (or (calendar-cursor-to-date) (let ((date (calendar-cursor-to-date t)))
(error "Cursor is not on a date!"))))
(if (null arg) (if (null arg)
(progn (progn
(setq calendar-mark-ring (cons date calendar-mark-ring)) (setq calendar-mark-ring (cons date calendar-mark-ring))
@ -2254,8 +2254,7 @@ With argument, jump to mark, pop it, and put point at end of ring."
"Exchange the current cursor position with the marked date." "Exchange the current cursor position with the marked date."
(interactive) (interactive)
(let ((mark (car calendar-mark-ring)) (let ((mark (car calendar-mark-ring))
(date (or (calendar-cursor-to-date) (date (calendar-cursor-to-date t)))
(error "Cursor is not on a date!"))))
(if (null mark) (if (null mark)
(error "No mark set in this buffer") (error "No mark set in this buffer")
(setq calendar-mark-ring (cons date (cdr calendar-mark-ring))) (setq calendar-mark-ring (cons date (cdr calendar-mark-ring)))
@ -2265,8 +2264,7 @@ With argument, jump to mark, pop it, and put point at end of ring."
"Count the number of days (inclusive) between point and the mark." "Count the number of days (inclusive) between point and the mark."
(interactive) (interactive)
(let* ((days (- (calendar-absolute-from-gregorian (let* ((days (- (calendar-absolute-from-gregorian
(or (calendar-cursor-to-date) (calendar-cursor-to-date t))
(error "Cursor is not on a date!")))
(calendar-absolute-from-gregorian (calendar-absolute-from-gregorian
(or (car calendar-mark-ring) (or (car calendar-mark-ring)
(error "No mark set in this buffer"))))) (error "No mark set in this buffer")))))
@ -2653,9 +2651,7 @@ Defaults to today's date if DATE is not given."
(defun calendar-print-day-of-year () (defun calendar-print-day-of-year ()
"Show day number in year/days remaining in year for date under the cursor." "Show day number in year/days remaining in year for date under the cursor."
(interactive) (interactive)
(message (calendar-day-of-year-string (message (calendar-day-of-year-string (calendar-cursor-to-date t))))
(or (calendar-cursor-to-date)
(error "Cursor is not on a date!")))))
(defun calendar-absolute-from-iso (date) (defun calendar-absolute-from-iso (date)
"The number of days elapsed between the Gregorian date 12/31/1 BC and DATE. "The number of days elapsed between the Gregorian date 12/31/1 BC and DATE.
@ -2709,9 +2705,7 @@ Defaults to today's date if DATE is not given."
"Show equivalent ISO date for the date under the cursor." "Show equivalent ISO date for the date under the cursor."
(interactive) (interactive)
(message "ISO date: %s" (message "ISO date: %s"
(calendar-iso-date-string (calendar-iso-date-string (calendar-cursor-to-date t))))
(or (calendar-cursor-to-date)
(error "Cursor is not on a date!")))))
(defun calendar-julian-from-absolute (date) (defun calendar-julian-from-absolute (date)
"Compute the Julian (month day year) corresponding to the absolute DATE. "Compute the Julian (month day year) corresponding to the absolute DATE.
@ -2767,9 +2761,7 @@ Driven by the variable `calendar-date-display-form'."
"Show the Julian calendar equivalent of the date under the cursor." "Show the Julian calendar equivalent of the date under the cursor."
(interactive) (interactive)
(message "Julian date: %s" (message "Julian date: %s"
(calendar-julian-date-string (calendar-julian-date-string (calendar-cursor-to-date t))))
(or (calendar-cursor-to-date)
(error "Cursor is not on a date!")))))
(defun islamic-calendar-leap-year-p (year) (defun islamic-calendar-leap-year-p (year)
"Returns t if YEAR is a leap year on the Islamic calendar." "Returns t if YEAR is a leap year on the Islamic calendar."
@ -2857,9 +2849,7 @@ Driven by the variable `calendar-date-display-form'."
(defun calendar-print-islamic-date () (defun calendar-print-islamic-date ()
"Show the Islamic calendar equivalent of the date under the cursor." "Show the Islamic calendar equivalent of the date under the cursor."
(interactive) (interactive)
(let ((i (calendar-islamic-date-string (let ((i (calendar-islamic-date-string (calendar-cursor-to-date t))))
(or (calendar-cursor-to-date)
(error "Cursor is not on a date!")))))
(if (string-equal i "") (if (string-equal i "")
(message "Date is pre-Islamic") (message "Date is pre-Islamic")
(message "Islamic date (until sunset): %s" i)))) (message "Islamic date (until sunset): %s" i))))
@ -3002,9 +2992,7 @@ Driven by the variable `calendar-date-display-form'."
"Show the Hebrew calendar equivalent of the date under the cursor." "Show the Hebrew calendar equivalent of the date under the cursor."
(interactive) (interactive)
(message "Hebrew date (until sunset): %s" (message "Hebrew date (until sunset): %s"
(calendar-hebrew-date-string (calendar-hebrew-date-string (calendar-cursor-to-date t))))
(or (calendar-cursor-to-date)
(error "Cursor is not on a date!")))))
(defun hebrew-calendar-yahrzeit (death-date year) (defun hebrew-calendar-yahrzeit (death-date year)
"Absolute date of the anniversary of Hebrew DEATH-DATE in Hebrew YEAR." "Absolute date of the anniversary of Hebrew DEATH-DATE in Hebrew YEAR."
@ -3130,9 +3118,7 @@ Defaults to today's date if DATE is not given."
(interactive) (interactive)
(message (message
"Astronomical (Julian) day number after noon UTC: %s" "Astronomical (Julian) day number after noon UTC: %s"
(calendar-astro-date-string (calendar-astro-date-string (calendar-cursor-to-date t))))
(or (calendar-cursor-to-date)
(error "Cursor is not on a date!")))))
(defun calendar-goto-astro-day-number (daynumber &optional noecho) (defun calendar-goto-astro-day-number (daynumber &optional noecho)
"Move cursor to astronomical (Julian) DAYNUMBER. "Move cursor to astronomical (Julian) DAYNUMBER.