-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCALE-JIS.LSP
89 lines (75 loc) · 3.21 KB
/
CALE-JIS.LSP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
;
; This piece of code written at 10-11. AUG 1991
; by Antti Karttunen $@!V%"%s%C%F%#!!%+%k%C%H%%%M%s!W(J
; Routines presented here are Public Domain.
;
; Use (start1 1923) and (start1 1983) to produce the Chinese-Japanese
; calendar output with JIS-kanji-characters.
;
(setq eto '($@7;(J $@Do(J)) ; (e=elder) and (to=younger).
(setq eto_kun '(e to))
(setq gogyoo '($@LZ(J $@2P(J $@EZ(J $@6b(J $@?e(J)) ; $@8^9T(J
(setq gogyoo_kun '(ki hi tsuchi ka mizu)) ; Kun-readings of gogyoo
(setq jikkan '($@9C(J $@25(J $@J:(J $@Cz(J $@Jj(J $@8J(J $@9.(J $@?I(J $@?Q(J $@b#(J)) ; $@==43(J
(setq juunishi '($@;R(J $@1/(J $@FR(J $@1,(J $@C$(J $@L&(J $@8a(J $@L$(J $@?=(J $@FS(J $@X|(J $@0g(J)) ; $@==Fs;Y(J
(setq juunishi_kun '(ne ushi tora u tatsu mi uma hitsuji saru tori inu i))
(defun assign_values (list1 list2)
(mapc #'(lambda (x y) (set x y))
list1 list2)
)
(assign_values eto eto_kun)
(assign_values gogyoo gogyoo_kun)
(assign_values juunishi juunishi_kun)
(defun start1 vlambda (x filename)
(testi1 x 1 (if (endmarkp filename) *stdout* (outfile filename 'a))
jikkan jikkan juunishi juunishi gogyoo gogyoo eto eto))
(defun start2 (x) (testi2 x jikkan jikkan juunishi juunishi))
(defun testi1 (year n output set1 pset1 set2 pset2 set3 pset3 set4 pset4)
; Stop when $@==43(J and $@==Fs;Y(J become nil at the SAME time:
(while (or set1 set2)
; If some of the sequences became nil, then circulate it back to start:
(if (null set1) (setq set1 pset1))
(if (null set2) (setq set2 pset2))
(if (null set3) (setq set3 pset3))
(if (null set4) (setq set4 pset4))
(prin1 (+ year n) output)
(spaces 1 output)
(prin1 n output)
(princ `\t` output)
(prin1 (car set1) output) ; $@==43(J
(prin1 (car set2) output) ; $@==Fs;Y(J
(spaces 1 output)
(prin1 (car set3) output) ; $@8^9T(J
(prin1 (car set4) output) ; $@7;(J or $@Do(J
(spaces 1 output)
(prin1 (eval (car set3)) output) ; $@8^9T(J $@71(J
(prin1 'no output)
(prin1 (eval (car set4)) output) ; e or to
(spaces 1 output)
(print (eval (car set2)) output) ; $@==Fs;Y(J $@71(J
(setq n (add1 n))
(setq set1 (cdr set1))
(setq set2 (cdr set2))
(setq set4 (cdr set4))
; Advance $@8^9T(J only after every second step:
(if (null set4) (setq set3 (cdr set3)))
) ; If wrote to $@%U%!%$%k(J, then close it:
(if (neq output *stdout*) (close output))
)
(defun testi2 (year jikkan1 jikkan2 juunishi1 juunishi2)
(cond ((null jikkan1)
(if (null jikkan2) () ; The END
(testi year (cdr jikkan2) () juunishi2 juunishi2)
)
)
((null juunishi1)
(testi year (cddr jikkan1) jikkan2 juunishi2 juunishi2))
(t
(prin1 (car jikkan1))
(prin1 (car juunishi1))
(princ `\t`)
(print year)
(testi (add1 year) jikkan1 jikkan2 (cdr juunishi1) juunishi2)
)
)
)