Initial version of minari.el
It has some bugs (or maybe my JS version has one). Yet, it’s feature-complete.
This commit is contained in:
parent
bf639efa20
commit
20389b6617
65
lisp/minari.el
Normal file
65
lisp/minari.el
Normal file
@ -0,0 +1,65 @@
|
||||
;;; minari.el --- Calculate Minari dates
|
||||
|
||||
;;; Commentary:
|
||||
;;
|
||||
|
||||
;;; Code:
|
||||
|
||||
(defconst minari-special-day-names
|
||||
'("Hëður" "Rideyy" "Morkh" "Morkh+" "Khmerd" "Chamog")
|
||||
"Names of the special (monthless) days of the year.")
|
||||
|
||||
(defconst minari-weekday-names
|
||||
'("Ro’unn" "Mïrdu" "Hëmi" "Drak" "Þodon" "Charm")
|
||||
"Names of weekdays.")
|
||||
|
||||
(defconst minari-month-names
|
||||
'("Mëbel" "Dirann" "Ma’uþ"
|
||||
"Gerub" "Þrei" "Dimoc"
|
||||
"Xentor" "Mëðïr" "Draþ"
|
||||
"Quaden" "Ridïmel" "Rodom")
|
||||
"Names of months.")
|
||||
|
||||
(defun minari-today-string ()
|
||||
"Calculate today's date according to the Minari Calendar."
|
||||
(let ((today (decode-time (current-time))))
|
||||
(message "%s" today)
|
||||
(setf (nth 3 today) (+ (nth 3 today) 11))
|
||||
(message "%s" today)
|
||||
(let* ((minari-leap (date-leap-year-p (nth 5 today)))
|
||||
(doy (time-to-day-in-year (apply 'encode-time today)))
|
||||
(minari-year (- (nth 5 today) 1873))
|
||||
(minari-month 0)
|
||||
(minari-doy 0)
|
||||
(minari-day 0)
|
||||
(minari-weekday 0)
|
||||
(minari-special-day -1))
|
||||
(cond
|
||||
((eq doy 0) (setq minari-special-day 0))
|
||||
((eq doy 91) (setq minari-special-day 1))
|
||||
((eq doy 182) (setq minari-special-day 2))
|
||||
((and (eq doy 183) minari-leap) (setq minari-special-day 3))
|
||||
((and (eq doy 273) (not minari-leap)) (setq minari-special-day 4))
|
||||
((and (eq doy 274) minari-leap) (setq minari-special-day 4))
|
||||
((and (eq doy 364) (not minari-leap)) (setq minari-special-day 5))
|
||||
((and (eq doy 365) minari-leap) (setq minari-special-day 5))
|
||||
(t (let ((decr 0)
|
||||
(minari-doy doy))
|
||||
(when (> minari-doy 0) (setq decr (1+ decr)))
|
||||
(when (> minari-doy 91) (setq decr (1+ decr)))
|
||||
(when (> minari-doy 182) (setq decr (1+ decr)))
|
||||
(when (and (> minari-doy 183) minari-leap) (setq decr (1+ decr)))
|
||||
(when (and (> minari-doy 273) (not minari-leap))
|
||||
(setq decr (1+ decr)))
|
||||
(when (and (> minari-doy 274) minari-leap) (setq decr (1+ decr)))
|
||||
(setq minari-doy (- minari-doy (1+ decr))
|
||||
minari-month (round (fceiling (/ minari-doy 30)))
|
||||
minari-day (% minari-doy 30))
|
||||
(when (eq minari-day 0) (setq minari-day 30))
|
||||
(setq minari-weekday (% minari-day 6)))))
|
||||
(message "%d %s %s" minari-year minari-month minari-day)
|
||||
)))
|
||||
|
||||
(provide 'minari)
|
||||
|
||||
;;; minari.el ends here
|
Loading…
Reference in New Issue
Block a user