Revision: 1.2 - (view) (download)
1 : | ktanaka | 1.1 | (defun rm-limit (prim) |
2 : | (do ((l (cadr prim) (cdr l))(ret)) | ||
3 : | ((atom l)`(,(car prim) ,(nreverse ret).,(cddr prim))) | ||
4 : | (or (memq (caar l) '(xlimit ylimit)) | ||
5 : | (push (car l) ret)))) | ||
6 : | (defun out-to-ps-all (outlines tag psfile | ||
7 : | (nameflag) | ||
8 : | (col 9)(line (fix (times 0.67 col))) | ||
9 : | (printfile t)) | ||
10 : | (lets ((standard-output (outopen (stream psfile))) | ||
11 : | (scale (fix (times 160.0 (min (//$ 9.0 (float col)) | ||
12 : | (//$ 6.0 (float line)))))) | ||
13 : | (ii nil)(jj nil)(page nil)(last nil) | ||
14 : | ktanaka | 1.2 | (skeleton)(hints)(type1)(kstr) |
15 : | ktanaka | 1.1 | (next nil)(nextnext nil)(x1 nil)(y1 nil)(x2 nil)(y2 nil) |
16 : | (date (date-time))) | ||
17 : | (format "%!/n%%BoundingBox: 45 45 /c /c/n" | ||
18 : | (plus 55 (fix (times 0.001 scale (- (* line 500) 100)))) | ||
19 : | (plus 55 (fix (times 0.001 scale (- (* col 500) 100))))) | ||
20 : | (lets ((s (inopen (stream "../psfiles/compfont.ps"))) | ||
21 : | (err:end-of-file #'(lambda (x (y))(throw 'eof)))) | ||
22 : | (catch 'eof (loop (princ (readline s))(terpri)))) | ||
23 : | (format "50 50 translate/n0.001 /c mul dup scale/n" scale) | ||
24 : | (format "//Helvetica findfont 70 scalefont setfont/n") | ||
25 : | (setq ii 0 jj 0 page 1) | ||
26 : | (and printfile | ||
27 : | (format "0 -70 moveto (/c-/c-/c /c:/c File: /c Page: /c) show/n" | ||
28 : | (substring date 0 2) | ||
29 : | (substring date 2 4)(substring date 4 6) | ||
30 : | (substring date 6 8)(substring date 8 10) | ||
31 : | psfile page)) | ||
32 : | (format "//Wadalab-mincho-10 CompNF/n") | ||
33 : | (format "//Wadalab-mincho-10 findfont 400 scalefont setfont/n") | ||
34 : | (do | ||
35 : | ((ol outlines (cdr ol)) | ||
36 : | (l nil)) | ||
37 : | ((atom ol)) | ||
38 : | (princ ";" terminal-output) | ||
39 : | ; (princ (gccount) terminal-output) | ||
40 : | (print (car ol) terminal-output) | ||
41 : | (setq l | ||
42 : | (let ((err:argument-type #'(lambda (x (y))(throw 'err))) | ||
43 : | (err:number-of-arguments #'(lambda (x (y))(throw 'err))) | ||
44 : | (err:unbound-variable #'(lambda (x (y))(throw 'err))) | ||
45 : | (err:undefined-function #'(lambda (x (y))(throw 'err))) | ||
46 : | (err:zero-division #'(lambda (x (y))(throw 'err)))) | ||
47 : | (catch 'err | ||
48 : | ktanaka | 1.2 | (skeleton2list (setq skeleton (normkanji (rm-limit (applykanji (car ol) tag)))) tag)))) |
49 : | ktanaka | 1.1 | (cond |
50 : | ((atom l) | ||
51 : | (format "0 setlinewidth newpath 0 0 moveto 400 0 lineto/n") | ||
52 : | (format "400 400 lineto 0 400 lineto 0 0 lineto stroke/n") | ||
53 : | ) | ||
54 : | (t | ||
55 : | (format "0 setlinewidth newpath 0 0 moveto 400 0 lineto/n") | ||
56 : | (format "400 400 lineto 0 400 lineto 0 0 lineto stroke/n") | ||
57 : | ktanaka | 1.2 | (setq hints (type1hints skeleton tag)) |
58 : | ktanaka | 1.1 | (setq type1 (out2type1 (makeoutline l) hints)) |
59 : | (cond ((and (= 2 (string-length (car ol))) | ||
60 : | (logand 128 (sref (car ol) 0))) | ||
61 : | (setq kstr (long-hex-image | ||
62 : | (plus (logand 127 (sref (car ol) 1)) | ||
63 : | (times 256 (logand 127 (sref (car ol) 0))))))) | ||
64 : | ((and (= 7 (string-length (car ol))) | ||
65 : | (string-equal (substring (car ol) 0 2) "1-")) | ||
66 : | (setq kstr | ||
67 : | (long-hex-image | ||
68 : | (plus (logand 127 (plus 32 (number-value (substring (car ol) 5 7)))) | ||
69 : | (times 256 (logand 127 (plus 32 (number-value (substring (car ol) 2 4))))))))) | ||
70 : | (t | ||
71 : | (setq kstr "2121"))) | ||
72 : | (princ type1) | ||
73 : | (format " </c> CompD/n" kstr) | ||
74 : | (format "0 70 moveto </c> show/n" kstr))) | ||
75 : | (setq ii (1+ ii)) | ||
76 : | (cond ((eq ii col) | ||
77 : | (format "500 /c translate/n" (* -500 (1- col))) | ||
78 : | (setq ii 0) | ||
79 : | (setq jj (1+ jj)) | ||
80 : | (cond ((and (eq jj line)(consp (cdr ol))) | ||
81 : | (format "showpage/n") | ||
82 : | (format "50 50 translate/n") | ||
83 : | (format "0.001 /c mul dup scale/n" scale) | ||
84 : | (format "//Helvetica findfont 70 scalefont setfont/n") | ||
85 : | (setq page (1+ page)) | ||
86 : | (and printfile | ||
87 : | (format "0 -70 moveto (/c-/c-/c /c:/c File: /c Page: /c) show/n" | ||
88 : | (substring date 0 2) | ||
89 : | (substring date 2 4)(substring date 4 6) | ||
90 : | (substring date 6 8)(substring date 8 10) | ||
91 : | psfile page)) | ||
92 : | (format "//Wadalab-mincho-10 CompNF/n") | ||
93 : | (format "//Wadalab-mincho-10 findfont 400 scalefont setfont/n") | ||
94 : | (setq jj 0)))) | ||
95 : | (t (format "0 500 translate/n")))) | ||
96 : | (format "showpage/n"))) |
ktanaka Powered by ViewCVS 1.0-dev |
ViewCVS and CVS Help |