annotate lisp/ps-mule.el @ 49506:ac9e2eeeb03d

New format of AUTHORS file; list each author name once followed by contributed and changed files. Improve selection of entries to include in list, and generate list of unrecognized entries indicating syntax errors in ChangeLog files. (authors-coding-system): New variable. (authors-many-files): Update doc string. (authors-aliases): Change format. Now one entry with multiple aliases per author. (authors-valid-file-names, authors-renamed-files-alist) (authors-renamed-files-regexps): New variables. (authors-canonical-file-name): New function. Validates that file exists or occurs in one of the above lists. Record unrecognized file names in global authors-invalid-file-names list. (authors-add): Change to record per-change counts. (authors-canonical-author-name): Handle new format of authors-aliases list. (authors-scan-change-log): Rename FILE arg to LOG-FILE. Change doc string to describe new entry format. Only add author entries for valid file names. (authors-print): Replace by authors-add-to-author-list. (authors-add-to-author-list): New function which reorders per-file entries and adds them to global authors-author-list. (authors): Instead of authors-print to insert in *Authors* buffer, use authors-add-to-author-list to reorder the list and then insert result in *Authors* buffer with new format. Generate *Authors Errors* compilation-mode buffer listing unrecognized ChangeLog entries.
author Kim F. Storm <storm@cua.dk>
date Wed, 29 Jan 2003 00:13:11 +0000
parents e44f3ea2c30c
children c3f9aa88ed68 d7ddb3e565de
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
38436
b174db545cfd Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents: 37201
diff changeset
1 ;;; ps-mule.el --- provide multi-byte character facility to ps-print
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
2
45334
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
3 ;; Copyright (C) 1998, 1999, 2000, 2001, 2002 Free Software Foundation, Inc.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
4
38436
b174db545cfd Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents: 37201
diff changeset
5 ;; Author: Vinicius Jose Latorre <vinicius@cpqd.com.br>
38816
e4e0e5593284 Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 38436
diff changeset
6 ;; Kenichi Handa <handa@etl.go.jp> (multi-byte characters)
e4e0e5593284 Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 38436
diff changeset
7 ;; Maintainer: Kenichi Handa <handa@etl.go.jp> (multi-byte characters)
e4e0e5593284 Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 38436
diff changeset
8 ;; Vinicius Jose Latorre <vinicius@cpqd.com.br>
38436
b174db545cfd Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents: 37201
diff changeset
9 ;; Keywords: wp, print, PostScript, multibyte, mule
38855
db1312628833 (find-composition): Check if (char-after POS)
Gerd Moellmann <gerd@gnu.org>
parents: 38816
diff changeset
10 ;; Time-stamp: <2001/08/15 15:34:11 vinicius>
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
11
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
12 ;; This file is part of GNU Emacs.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
13
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
14 ;; GNU Emacs is free software; you can redistribute it and/or modify
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
15 ;; it under the terms of the GNU General Public License as published by
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
16 ;; the Free Software Foundation; either version 2, or (at your option)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
17 ;; any later version.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
18
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
19 ;; GNU Emacs is distributed in the hope that it will be useful,
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
20 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
21 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
22 ;; GNU General Public License for more details.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
23
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
24 ;; You should have received a copy of the GNU General Public License
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
25 ;; along with GNU Emacs; see the file COPYING. If not, write to the
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
26 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
27 ;; Boston, MA 02111-1307, USA.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
28
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
29 ;;; Commentary:
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
30
26115
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
31 ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
32 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
33 ;; About ps-mule
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
34 ;; -------------
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
35 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
36 ;; This package is used for ps-print to print multi-byte buffer.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
37 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
38 ;; See also ps-print.el.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
39 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
40 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
41 ;; Printing Multi-byte Buffer
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
42 ;; --------------------------
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
43 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
44 ;; The variable `ps-multibyte-buffer' specifies the ps-print multi-byte buffer
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
45 ;; handling.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
46 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
47 ;; Valid values for `ps-multibyte-buffer' are:
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
48 ;;
26115
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
49 ;; nil This is the value to use the default settings which
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
50 ;; is by default for printing buffer with only ASCII
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
51 ;; and Latin characters. The default setting can be
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
52 ;; changed by setting the variable
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
53 ;; `ps-mule-font-info-database-default' differently.
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
54 ;; The initial value of this variable is
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
55 ;; `ps-mule-font-info-database-latin' (see
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
56 ;; documentation).
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
57 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
58 ;; `non-latin-printer' This is the value to use when you have a japanese
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
59 ;; or korean PostScript printer and want to print
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
60 ;; buffer with ASCII, Latin-1, Japanese (JISX0208 and
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
61 ;; JISX0201-Kana) and Korean characters. At present,
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
62 ;; it was not tested the Korean characters printing.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
63 ;; If you have a korean PostScript printer, please,
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
64 ;; test it.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
65 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
66 ;; `bdf-font' This is the value to use when you want to print
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
67 ;; buffer with BDF fonts. BDF fonts include both latin
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
68 ;; and non-latin fonts. BDF (Bitmap Distribution
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
69 ;; Format) is a format used for distributing X's font
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
70 ;; source file. BDF fonts are included in
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
71 ;; `intlfonts-1.2' which is a collection of X11 fonts
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
72 ;; for all characters supported by Emacs. In order to
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
73 ;; use this value, be sure to have installed
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
74 ;; `intlfonts-1.2' and set the variable
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
75 ;; `bdf-directory-list' appropriately (see ps-bdf.el
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
76 ;; for documentation of this variable).
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
77 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
78 ;; `bdf-font-except-latin' This is like `bdf-font' except that it is used
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
79 ;; PostScript default fonts to print ASCII and Latin-1
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
80 ;; characters. This is convenient when you want or
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
81 ;; need to use both latin and non-latin characters on
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
82 ;; the same buffer. See `ps-font-family',
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
83 ;; `ps-header-font-family' and `ps-font-info-database'.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
84 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
85 ;; Any other value is treated as nil.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
86 ;;
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
87 ;; The default is nil.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
88 ;;
26115
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
89 ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
90
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
91 ;;; Code:
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
92
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
93 (eval-and-compile
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
94 (require 'ps-print)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
95
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
96 ;; to avoid XEmacs compilation gripes
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
97 (defvar leading-code-private-22 157)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
98 (or (fboundp 'charset-bytes)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
99 (defun charset-bytes (charset) 1)) ; ascii
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
100 (or (fboundp 'charset-dimension)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
101 (defun charset-dimension (charset) 1)) ; ascii
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
102 (or (fboundp 'charset-id)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
103 (defun charset-id (charset) 0)) ; ascii
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
104 (or (fboundp 'charset-width)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
105 (defun charset-width (charset) 1)) ; ascii
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
106 (or (fboundp 'find-charset-region)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
107 (defun find-charset-region (beg end &optional table)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
108 (list 'ascii)))
37201
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
109 (or (fboundp 'char-valid-p)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
110 (defun char-valid-p (char)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
111 (< (following-char) 256)))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
112 (or (fboundp 'split-char)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
113 (defun split-char (char)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
114 (list (if (char-valid-p char)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
115 'ascii
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
116 'unknow)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
117 char)))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
118 (or (fboundp 'char-width)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
119 (defun char-width (char) 1)) ; ascii
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
120 (or (fboundp 'chars-in-region)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
121 (defun chars-in-region (beg end)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
122 (- (max beg end) (min beg end))))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
123 (or (fboundp 'forward-point)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
124 (defun forward-point (arg)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
125 (save-excursion
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
126 (let ((count (abs arg))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
127 (step (if (zerop arg)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
128 0
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
129 (/ arg arg))))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
130 (while (and (> count 0)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
131 (< (point-min) (point)) (< (point) (point-max)))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
132 (forward-char step)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
133 (setq count (1- count)))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
134 (+ (point) (* count step))))))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
135 (or (fboundp 'decompose-composite-char)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
136 (defun decompose-composite-char (char &optional type
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
137 with-composition-rule)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
138 nil))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
139 (or (fboundp 'encode-coding-string)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
140 (defun encode-coding-string (string coding-system &optional nocopy)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
141 (if nocopy
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
142 string
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
143 (copy-sequence string))))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
144 (or (fboundp 'coding-system-p)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
145 (defun coding-system-p (obj) nil))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
146 (or (fboundp 'ccl-execute-on-string)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
147 (defun ccl-execute-on-string (ccl-prog status str
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
148 &optional contin unibyte-p)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
149 str))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
150 (or (fboundp 'define-ccl-program)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
151 (defmacro define-ccl-program (name ccl-program &optional doc)
37201
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
152 `(defconst ,name nil ,doc)))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
153 (or (fboundp 'multibyte-string-p)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
154 (defun multibyte-string-p (str)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
155 (let ((len (length str))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
156 (i 0)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
157 multibyte)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
158 (while (and (< i len) (not (setq multibyte (> (aref str i) 255))))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
159 (setq i (1+ i)))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
160 multibyte)))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
161 (or (fboundp 'string-make-multibyte)
45334
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
162 (defalias 'string-make-multibyte 'copy-sequence))
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
163 (or (fboundp 'encode-char)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
164 (defun encode-char (ch ccs)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
165 ch)))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
166
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
167
27160
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
168 ;;;###autoload
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
169 (defcustom ps-multibyte-buffer nil
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
170 "*Specifies the multi-byte buffer handling.
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
171
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
172 Valid values are:
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
173
27160
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
174 nil This is the value to use the default settings which
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
175 is by default for printing buffer with only ASCII
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
176 and Latin characters. The default setting can be
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
177 changed by setting the variable
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
178 `ps-mule-font-info-database-default' differently.
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
179 The initial value of this variable is
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
180 `ps-mule-font-info-database-latin' (see
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
181 documentation).
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
182
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
183 `non-latin-printer' This is the value to use when you have a Japanese
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
184 or Korean PostScript printer and want to print
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
185 buffer with ASCII, Latin-1, Japanese (JISX0208 and
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
186 JISX0201-Kana) and Korean characters. At present,
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
187 it was not tested the Korean characters printing.
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
188 If you have a korean PostScript printer, please,
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
189 test it.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
190
27160
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
191 `bdf-font' This is the value to use when you want to print
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
192 buffer with BDF fonts. BDF fonts include both latin
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
193 and non-latin fonts. BDF (Bitmap Distribution
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
194 Format) is a format used for distributing X's font
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
195 source file. BDF fonts are included in
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
196 `intlfonts-1.2' which is a collection of X11 fonts
27160
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
197 for all characters supported by Emacs. In order to
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
198 use this value, be sure to have installed
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
199 `intlfonts-1.2' and set the variable
27160
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
200 `bdf-directory-list' appropriately (see ps-bdf.el for
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
201 documentation of this variable).
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
202
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
203 `bdf-font-except-latin' This is like `bdf-font' except that it is used
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
204 PostScript default fonts to print ASCII and Latin-1
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
205 characters. This is convenient when you want or
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
206 need to use both latin and non-latin characters on
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
207 the same buffer. See `ps-font-family',
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
208 `ps-header-font-family' and `ps-font-info-database'.
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
209
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
210 Any other value is treated as nil."
28631
5e9674136340 Customization fix, doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 27160
diff changeset
211 :type '(choice (const non-latin-printer) (const bdf-font)
5e9674136340 Customization fix, doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 27160
diff changeset
212 (const bdf-font-except-latin) (const :tag "nil" nil))
27160
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
213 :group 'ps-print-font)
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
214
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
215
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
216 (eval-and-compile
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
217 ;; For Emacs 20.2 and the earlier version.
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
218 (if (and (boundp 'mule-version)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
219 (not (string< (symbol-value 'mule-version) "4.0")))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
220 ;; mule package is loaded
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
221 (progn
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
222 (defalias 'ps-mule-next-point '1+)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
223 (defalias 'ps-mule-chars-in-string 'length)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
224 (defalias 'ps-mule-string-char 'aref)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
225 (defsubst ps-mule-next-index (str i) (1+ i)))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
226 ;; mule package isn't loaded or mule version lesser than 4.0
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
227 (defun ps-mule-next-point (arg)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
228 (save-excursion (goto-char arg) (forward-char 1) (point)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
229 (defun ps-mule-chars-in-string (string)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
230 (/ (length string)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
231 (charset-bytes (char-charset (string-to-char string)))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
232 (defun ps-mule-string-char (string idx)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
233 (string-to-char (substring string idx)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
234 (defun ps-mule-next-index (string i)
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
235 (+ i (charset-bytes (char-charset (string-to-char string)))))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
236 )
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
237 ;; For Emacs 20.4 and the earlier version.
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
238 (if (and (boundp 'mule-version)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
239 (string< (symbol-value 'mule-version) "5.0"))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
240 ;; mule package is loaded and mule version is lesser than 5.0
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
241 (progn
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
242 (defun encode-composition-rule (rule)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
243 (if (= (car rule) 4) (setcar rule 10))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
244 (if (= (cdr rule) 4) (setcdr rule 10))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
245 (+ (* (car rule) 12) (cdr rule)))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
246 (defun find-composition (pos &rest ignore)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
247 (let ((ch (char-after pos)))
38855
db1312628833 (find-composition): Check if (char-after POS)
Gerd Moellmann <gerd@gnu.org>
parents: 38816
diff changeset
248 (and ch (eq (char-charset ch) 'composition)
db1312628833 (find-composition): Check if (char-after POS)
Gerd Moellmann <gerd@gnu.org>
parents: 38816
diff changeset
249 (let ((components (decompose-composite-char ch 'vector t)))
db1312628833 (find-composition): Check if (char-after POS)
Gerd Moellmann <gerd@gnu.org>
parents: 38816
diff changeset
250 (list pos (ps-mule-next-point pos) components
db1312628833 (find-composition): Check if (char-after POS)
Gerd Moellmann <gerd@gnu.org>
parents: 38816
diff changeset
251 (integerp (aref components 1)) nil
db1312628833 (find-composition): Check if (char-after POS)
Gerd Moellmann <gerd@gnu.org>
parents: 38816
diff changeset
252 (char-width ch)))))))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
253 ;; mule package isn't loaded
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
254 (or (fboundp 'encode-composition-rule)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
255 (defun encode-composition-rule (rule)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
256 130))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
257 (or (fboundp 'find-composition)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
258 (defun find-composition (pos &rest ignore)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
259 nil))
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
260 ))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
261
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
262 (defvar ps-mule-font-info-database
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
263 nil
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
264 "Alist of charsets with the corresponding font information.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
265 Each element has the form:
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
266
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
267 (CHARSET (FONT-TYPE FONT-SRC FONT-NAME ENCODING BYTES) ...)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
268
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
269 Where
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
270
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
271 CHARSET is a charset (symbol) for this font family,
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
272
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
273 FONT-TYPE is a font type: normal, bold, italic, or bold-italic.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
274
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
275 FONT-SRC is a font source: builtin, ps-bdf, vflib, or nil.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
276
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
277 If FONT-SRC is builtin, FONT-NAME is a built-in PostScript font name.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
278
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
279 If FONT-SRC is bdf, FONT-NAME is a BDF font file name, or a list of
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
280 alternative font names. To use this font, the external library `ps-bdf'
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
281 is required.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
282
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
283 If FONT-SRC is vflib, FONT-NAME is the name of a font that VFlib knows.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
284 To use this font, the external library `vflib' is required.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
285
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
286 If FONT-SRC is nil, a proper ASCII font in the variable
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
287 `ps-font-info-database' is used. This is useful for Latin-1 characters.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
288
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
289 ENCODING is a coding system to encode a string of characters of CHARSET into a
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
290 proper string matching an encoding of the specified font. ENCODING may be a
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
291 function that does this encoding. In this case, the function is called with
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
292 one argument, the string to encode, and it should return an encoded string.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
293
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
294 BYTES specifies how many bytes each character has in the encoded byte
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
295 sequence; it should be 1 or 2.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
296
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
297 All multi-byte characters are printed by fonts specified in this database
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
298 regardless of a font family of ASCII characters. The exception is Latin-1
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
299 characters which are printed by the same font as ASCII characters, thus obey
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
300 font family.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
301
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
302 See also the variable `ps-font-info-database'.")
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
303
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
304 (defconst ps-mule-font-info-database-latin
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
305 '((latin-iso8859-1
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
306 (normal nil nil iso-latin-1)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
307 "Sample setting of `ps-mule-font-info-database' to use latin fonts.")
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
308
26115
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
309 (defcustom ps-mule-font-info-database-default
24307
6909b106c5c6 (ps-mule-font-info-database-default): Set the initial
Kenichi Handa <handa@m17n.org>
parents: 24306
diff changeset
310 ps-mule-font-info-database-latin
30561
fb68d65b0fa3 Fix a customization problem on
Gerd Moellmann <gerd@gnu.org>
parents: 29523
diff changeset
311 "*The default setting to use when `ps-multibyte-buffer' is nil."
fb68d65b0fa3 Fix a customization problem on
Gerd Moellmann <gerd@gnu.org>
parents: 29523
diff changeset
312 :type '(symbol :tag "Multi-Byte Buffer Database Font Default")
26115
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
313 :group 'ps-print-font)
24306
432510346b14 (ps-multibyte-buffer): Doc-string modified.
Kenichi Handa <handa@m17n.org>
parents: 24303
diff changeset
314
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
315 (defconst ps-mule-font-info-database-ps
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
316 '((katakana-jisx0201
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
317 (normal builtin "Ryumin-Light.Katakana" ps-mule-encode-7bit 1)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
318 (bold builtin "GothicBBB-Medium.Katakana" ps-mule-encode-7bit 1)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
319 (bold-italic builtin "GothicBBB-Medium.Katakana" ps-mule-encode-7bit 1))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
320 (latin-jisx0201
25828
55e4513821f8 (ps-mule-font-info-database-ps): Typo fixed
Kenichi Handa <handa@m17n.org>
parents: 25086
diff changeset
321 (normal builtin "Ryumin-Light.Hankaku" ps-mule-encode-7bit 1)
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
322 (bold builtin "GothicBBB-Medium.Hankaku" ps-mule-encode-7bit 1))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
323 (japanese-jisx0208
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
324 (normal builtin "Ryumin-Light-H" ps-mule-encode-7bit 2)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
325 (bold builtin "GothicBBB-Medium-H" ps-mule-encode-7bit 2))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
326 (korean-ksc5601
25828
55e4513821f8 (ps-mule-font-info-database-ps): Typo fixed
Kenichi Handa <handa@m17n.org>
parents: 25086
diff changeset
327 (normal builtin "Munhwa-Regular-KSC-EUC-H" ps-mule-encode-7bit 2)
55e4513821f8 (ps-mule-font-info-database-ps): Typo fixed
Kenichi Handa <handa@m17n.org>
parents: 25086
diff changeset
328 (bold builtin "Munhwa-Bold-KSC-EUC-H" ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
329 )
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
330 "Sample setting of the `ps-mule-font-info-database' to use builtin PS font.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
331
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
332 Currently, data for Japanese and Korean PostScript printers are listed.")
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
333
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
334 (defconst ps-mule-font-info-database-bdf
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
335 '((ascii
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
336 (normal bdf ("lt1-24-etl.bdf" "etl24-latin1.bdf") nil 1)
24303
958f4aa0dceb (ps-mule-font-info-database-bdf): Fix ENCODING field
Kenichi Handa <handa@m17n.org>
parents: 24086
diff changeset
337 (bold bdf ("lt1-16b-etl.bdf" "etl16b-latin1.bdf") nil 1)
958f4aa0dceb (ps-mule-font-info-database-bdf): Fix ENCODING field
Kenichi Handa <handa@m17n.org>
parents: 24086
diff changeset
338 (italic bdf ("lt1-16i-etl.bdf" "etl16i-latin1.bdf") nil 1)
958f4aa0dceb (ps-mule-font-info-database-bdf): Fix ENCODING field
Kenichi Handa <handa@m17n.org>
parents: 24086
diff changeset
339 (bold-italic bdf ("lt1-16bi-etl.bdf" "etl16bi-latin1.bdf") nil 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
340 (latin-iso8859-1
24303
958f4aa0dceb (ps-mule-font-info-database-bdf): Fix ENCODING field
Kenichi Handa <handa@m17n.org>
parents: 24086
diff changeset
341 (normal bdf ("lt1-24-etl.bdf" "etl24-latin1.bdf") iso-latin-1 1)
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
342 (bold bdf ("lt1-16b-etl.bdf" "etl16b-latin1.bdf") iso-latin-1 1)
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
343 (italic bdf ("lt1-16i-etl.bdf" "etl16i-latin1.bdf") iso-latin-1 1)
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
344 (bold-italic bdf ("lt1-16bi-etl.bdf" "etl16bi-latin1.bdf") iso-latin-1 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
345 (latin-iso8859-2
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
346 (normal bdf ("lt2-24-etl.bdf" "etl24-latin2.bdf") iso-latin-2 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
347 (latin-iso8859-3
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
348 (normal bdf ("lt3-24-etl.bdf" "etl24-latin3.bdf") iso-latin-3 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
349 (latin-iso8859-4
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
350 (normal bdf ("lt4-24-etl.bdf" "etl24-latin4.bdf") iso-latin-4 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
351 (thai-tis620
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
352 (normal bdf ("thai24.bdf" "thai-24.bdf") thai-tis620 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
353 (greek-iso8859-7
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
354 (normal bdf ("grk24-etl.bdf" "etl24-greek.bdf") greek-iso-8bit 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
355 ;; (arabic-iso8859-6 nil) ; not yet available
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
356 (hebrew-iso8859-8
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
357 (normal bdf ("heb24-etl.bdf" "etl24-hebrew.bdf") hebrew-iso-8bit 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
358 (katakana-jisx0201
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
359 (normal bdf "12x24rk.bdf" ps-mule-encode-8bit 1))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
360 (latin-jisx0201
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
361 (normal bdf "12x24rk.bdf" ps-mule-encode-7bit 1))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
362 (cyrillic-iso8859-5
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
363 (normal bdf ("cyr24-etl.bdf" "etl24-cyrillic.bdf") cyrillic-iso-8bit 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
364 (latin-iso8859-9
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
365 (normal bdf ("lt5-24-etl.bdf" "etl24-latin5.bdf") iso-latin-5 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
366 (japanese-jisx0208-1978
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
367 (normal bdf "jiskan24.bdf" ps-mule-encode-7bit 2))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
368 (chinese-gb2312
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
369 (normal bdf "gb24st.bdf" ps-mule-encode-7bit 2))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
370 (japanese-jisx0208
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
371 (normal bdf "jiskan24.bdf" ps-mule-encode-7bit 2))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
372 (korean-ksc5601
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
373 (normal bdf "hanglm24.bdf" ps-mule-encode-7bit 2))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
374 (japanese-jisx0212
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
375 (normal bdf ("jksp40.bdf" "jisksp40.bdf") ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
376 (chinese-cns11643-1
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
377 (normal bdf ("cns1-40.bdf" "cns-1-40.bdf") ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
378 (chinese-cns11643-2
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
379 (normal bdf ("cns2-40.bdf" "cns-2-40.bdf") ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
380 (chinese-big5-1
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
381 (normal bdf "taipei24.bdf" chinese-big5 2))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
382 (chinese-big5-2
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
383 (normal bdf "taipei24.bdf" chinese-big5 2))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
384 (chinese-sisheng
26512
a6cf126fdf97 (ps-mule-font-info-database-bdf): Default BDF font
Kenichi Handa <handa@m17n.org>
parents: 26483
diff changeset
385 (normal bdf ("sish24-etl.bdf" "etl24-sisheng.bdf") ps-mule-encode-7bit 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
386 (ipa
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
387 (normal bdf ("ipa24-etl.bdf" "etl24-ipa.bdf") ps-mule-encode-8bit 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
388 (vietnamese-viscii-lower
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
389 (normal bdf ("visc24-etl.bdf" "etl24-viscii.bdf") vietnamese-viscii 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
390 (vietnamese-viscii-upper
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
391 (normal bdf ("visc24-etl.bdf" "etl24-viscii.bdf") vietnamese-viscii 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
392 (arabic-digit
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
393 (normal bdf ("arab24-0-etl.bdf" "etl24-arabic0.bdf") ps-mule-encode-7bit 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
394 (arabic-1-column
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
395 (normal bdf ("arab24-1-etl.bdf" "etl24-arabic1.bdf") ps-mule-encode-7bit 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
396 ;; (ascii-right-to-left nil) ; not yet available
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
397 (lao
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
398 (normal bdf ("lao24-mule.bdf" "mule-lao-24.bdf") lao 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
399 (arabic-2-column
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
400 (normal bdf ("arab24-2-etl.bdf" "etl24-arabic2.bdf") ps-mule-encode-7bit 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
401 (indian-is13194
37149
92239370ac9f (ps-mule-font-info-database-bdf): Change
Gerd Moellmann <gerd@gnu.org>
parents: 37140
diff changeset
402 (normal bdf ("isci24-mule.bdf" "mule-iscii-24.bdf") ps-mule-encode-7bit 1))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
403 (indian-1-column
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
404 (normal bdf ("ind1c24-mule.bdf" "mule-indian-1col-24.bdf") ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
405 (tibetan-1-column
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
406 (normal bdf ("tib1c24-mule.bdf" "mule-tibmdx-1col-24.bdf") ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
407 (ethiopic
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
408 (normal bdf ("ethio24f-uni.bdf" "ethiomx24f-uni.bdf") ps-mule-encode-ethiopic 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
409 (chinese-cns11643-3
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
410 (normal bdf ("cns3-40.bdf" "cns-3-40.bdf") ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
411 (chinese-cns11643-4
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
412 (normal bdf ("cns4-40.bdf" "cns-4-40.bdf") ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
413 (chinese-cns11643-5
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
414 (normal bdf ("cns5-40.bdf" "cns-5-40.bdf") ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
415 (chinese-cns11643-6
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
416 (normal bdf ("cns6-40.bdf" "cns-6-40.bdf") ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
417 (chinese-cns11643-7
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
418 (normal bdf ("cns7-40.bdf" "cns-7-40.bdf") ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
419 (indian-2-column
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
420 (normal bdf ("ind24-mule.bdf" "mule-indian-24.bdf") ps-mule-encode-7bit 2))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
421 (tibetan
29523
33994562b445 (ps-mule-font-info-database-bdf): Prefer the font "tib24p-mule.bdf"
Kenichi Handa <handa@m17n.org>
parents: 28631
diff changeset
422 (normal bdf ("tib24p-mule.bdf" "tib24-mule.bdf" "mule-tibmdx-24.bdf")
45334
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
423 ps-mule-encode-7bit 2))
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
424 (mule-unicode-0100-24ff
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
425 (normal bdf "etl24-unicode.bdf" ps-mule-encode-ucs2 2))
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
426 (mule-unicode-2500-33ff
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
427 (normal bdf "etl24-unicode.bdf" ps-mule-encode-ucs2 2))
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
428 (mule-unicode-e000-ffff
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
429 (normal bdf "etl24-unicode.bdf" ps-mule-encode-ucs2 2)))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
430 "Sample setting of the `ps-mule-font-info-database' to use BDF fonts.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
431 BDF (Bitmap Distribution Format) is a format used for distributing X's font
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
432 source file.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
433
45334
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
434 Current default value list for BDF fonts is included in `intlfonts-1.2'
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
435 which is a collection of X11 fonts for all characters supported by Emacs.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
436
45334
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
437 Using this list as default value to `ps-mule-font-info-database', all
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
438 characters including ASCII and Latin-1 are printed by BDF fonts.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
439
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
440 See also `ps-mule-font-info-database-ps-bdf'.")
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
441
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
442 (defconst ps-mule-font-info-database-ps-bdf
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
443 (cons (car ps-mule-font-info-database-latin)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
444 (cdr (cdr ps-mule-font-info-database-bdf)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
445 "Sample setting of the `ps-mule-font-info-database' to use BDF fonts.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
446
45334
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
447 Current default value list for BDF fonts is included in `intlfonts-1.2'
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
448 which is a collection of X11 fonts for all characters supported by Emacs.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
449
45334
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
450 Using this list as default value to `ps-mule-font-info-database', all
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
451 characters except ASCII and Latin-1 characters are printed with BDF fonts.
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
452 ASCII and Latin-1 characters are printed with PostScript font specified
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
453 by `ps-font-family' and `ps-header-font-family'.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
454
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
455 See also `ps-mule-font-info-database-bdf'.")
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
456
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
457 ;; Two typical encoding functions for PostScript fonts.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
458
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
459 (defun ps-mule-encode-7bit (string)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
460 (ps-mule-encode-bit string 0))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
461
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
462 (defun ps-mule-encode-8bit (string)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
463 (ps-mule-encode-bit string 128))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
464
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
465 (defun ps-mule-encode-bit (string delta)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
466 (let* ((dim (charset-dimension (char-charset (string-to-char string))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
467 (len (* (ps-mule-chars-in-string string) dim))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
468 (str (make-string len 0))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
469 (i 0)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
470 (j 0))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
471 (if (= dim 1)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
472 (while (< j len)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
473 (aset str j
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
474 (+ (nth 1 (split-char (ps-mule-string-char string i))) delta))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
475 (setq i (ps-mule-next-index string i)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
476 j (1+ j)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
477 (while (< j len)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
478 (let ((split (split-char (ps-mule-string-char string i))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
479 (aset str j (+ (nth 1 split) delta))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
480 (aset str (1+ j) (+ (nth 2 split) delta))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
481 (setq i (ps-mule-next-index string i)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
482 j (+ j 2)))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
483 str))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
484
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
485 ;; Special encoding function for Ethiopic.
26115
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
486 (if (boundp 'mule-version) ; only if mule package is loaded
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
487 (define-ccl-program ccl-encode-ethio-unicode
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
488 `(1
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
489 ((read r2)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
490 (loop
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
491 (if (r2 == ,leading-code-private-22)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
492 ((read r0)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
493 (if (r0 == ,(charset-id 'ethiopic))
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
494 ((read r1 r2)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
495 (r1 &= 127) (r2 &= 127)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
496 (call ccl-encode-ethio-font)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
497 (write r1)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
498 (write-read-repeat r2))
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
499 ((write r2 r0)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
500 (repeat))))
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
501 (write-read-repeat r2))))))
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
502 ;; to avoid compilation gripes
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
503 (defvar ccl-encode-ethio-unicode nil))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
504
26115
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
505 (if (boundp 'mule-version)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
506 ;; bound mule-version
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
507 (defun ps-mule-encode-ethiopic (string)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
508 (ccl-execute-on-string (symbol-value 'ccl-encode-ethio-unicode)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
509 (make-vector 9 nil)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
510 string))
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
511 ;; unbound mule-version
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
512 (defun ps-mule-encode-ethiopic (string)
314173e121ee Doc fix, define functions properly if mule package is
Kenichi Handa <handa@m17n.org>
parents: 25828
diff changeset
513 string))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
514
45334
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
515 ;; Special encoding for mule-unicode-* characters.
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
516 (defun ps-mule-encode-ucs2 (string)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
517 (let* ((len (ps-mule-chars-in-string string))
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
518 (str (make-string (* 2 len) 0))
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
519 (i 0)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
520 (j 0)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
521 ch hi lo)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
522 (while (< i len)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
523 (setq ch (encode-char (ps-mule-string-char string i) 'ucs)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
524 hi (lsh ch -8)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
525 lo (logand ch 255))
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
526 (aset str j hi)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
527 (aset str (1+ j) lo)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
528 (setq i (1+ i)
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
529 j (+ j 2)))
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
530 str))
695ae1bd8fa4 (eval-and-compile): Add a trivial replacement for a
Eli Zaretskii <eliz@gnu.org>
parents: 39353
diff changeset
531
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
532 ;; A charset which we are now processing.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
533 (defvar ps-mule-current-charset nil)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
534
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
535 (defun ps-mule-get-font-spec (charset font-type)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
536 "Return FONT-SPEC for printing characters CHARSET with FONT-TYPE.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
537 FONT-SPEC is a list that has the form:
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
538
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
539 (FONT-SRC FONT-NAME ENCODING BYTES)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
540
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
541 FONT-SPEC is extracted from `ps-mule-font-info-database'.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
542
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
543 See the documentation of `ps-mule-font-info-database' for the meaning of each
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
544 element of the list."
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
545 (let ((slot (cdr (assq charset ps-mule-font-info-database))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
546 (and slot
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
547 (cdr (or (assq font-type slot)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
548 (and (eq font-type 'bold-italic)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
549 (or (assq 'bold slot) (assq 'italic slot)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
550 (assq 'normal slot))))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
551
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
552 ;; Functions to access each element of FONT-SPEC.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
553 (defsubst ps-mule-font-spec-src (font-spec) (car font-spec))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
554 (defsubst ps-mule-font-spec-name (font-spec) (nth 1 font-spec))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
555 (defsubst ps-mule-font-spec-encoding (font-spec) (nth 2 font-spec))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
556 (defsubst ps-mule-font-spec-bytes (font-spec) (nth 3 font-spec))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
557
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
558 (defsubst ps-mule-printable-p (charset)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
559 "Non-nil if characters in CHARSET is printable."
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
560 (ps-mule-get-font-spec charset 'normal))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
561
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
562 (defconst ps-mule-external-libraries
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
563 '((builtin nil nil
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
564 nil nil nil)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
565 (bdf ps-bdf nil
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
566 bdf-generate-prologue bdf-generate-font bdf-generate-glyphs)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
567 (pcf nil nil
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
568 pcf-generate-prologue pcf-generate-font pcf-generate-glyphs)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
569 (vflib nil nil
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
570 vflib-generate-prologue vflib-generate-font vflib-generate-glyphs))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
571 "Alist of information of external libraries to support PostScript printing.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
572 Each element has the form:
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
573
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
574 (FONT-SRC FEATURE INITIALIZED-P PROLOGUE-FUNC FONT-FUNC GLYPHS-FUNC)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
575
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
576 FONT-SRC is the font source: builtin, bdf, pcf, or vflib.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
577
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
578 FEATURE is the feature that provide a facility to handle FONT-SRC. Except for
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
579 `builtin' FONT-SRC, this feature is automatically `require'd before handling
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
580 FONT-SRC. Currently, we only have the feature `ps-bdf'.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
581
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
582 INITIALIZED-P indicates if this library is initialized or not.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
583
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
584 PROLOGUE-FUNC is a function to generate PostScript code which define several
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
585 PostScript procedures that will be called by FONT-FUNC and GLYPHS-FUNC. It is
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
586 called with no argument, and should return a list of strings.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
587
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
588 FONT-FUNC is a function to generate PostScript code which define a new font. It
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
589 is called with one argument FONT-SPEC, and should return a list of strings.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
590
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
591 GLYPHS-FUNC is a function to generate PostScript code which define glyphs of
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
592 characters. It is called with three arguments FONT-SPEC, CODE-LIST, and BYTES,
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
593 and should return a list of strings.")
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
594
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
595 (defun ps-mule-init-external-library (font-spec)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
596 "Initialize external library specified by FONT-SPEC for PostScript printing.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
597 See the documentation of `ps-mule-get-font-spec' for FONT-SPEC's meaning."
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
598 (let* ((font-src (ps-mule-font-spec-src font-spec))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
599 (slot (assq font-src ps-mule-external-libraries)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
600 (or (not font-src)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
601 (nth 2 slot)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
602 (let ((func (nth 3 slot)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
603 (if func
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
604 (progn
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
605 (require (nth 1 slot))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
606 (ps-output-prologue (funcall func))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
607 (setcar (nthcdr 2 slot) t)))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
608
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
609 ;; Cached glyph information of fonts, alist of:
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
610 ;; (FONT-NAME ((FONT-TYPE-NUMBER . SCALED-FONT-NAME) ...)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
611 ;; cache CODE0 CODE1 ...)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
612 (defvar ps-mule-font-cache nil)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
613
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
614 (defun ps-mule-generate-font (font-spec charset &optional header-p)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
615 "Generate PostScript codes to define a new font in FONT-SPEC for CHARSET.
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
616
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
617 If optional 3rd arg HEADER-P is non-nil, generate codes to define a header
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
618 font."
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
619 (let* ((font-name (ps-mule-font-spec-name font-spec))
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
620 (font-name (if (consp font-name) (car font-name) font-name))
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
621 (font-cache (assoc font-name ps-mule-font-cache))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
622 (font-src (ps-mule-font-spec-src font-spec))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
623 (func (nth 4 (assq font-src ps-mule-external-libraries)))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
624 (font-size (if header-p (if (eq ps-current-font 0)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
625 ps-header-title-font-size-internal
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
626 ps-header-font-size-internal)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
627 ps-font-size-internal))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
628 (current-font (+ ps-current-font (if header-p 10 0)))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
629 (scaled-font-name
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
630 (cond (header-p
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
631 (format "h%d" ps-current-font))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
632 ((eq charset 'ascii)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
633 (format "f%d" ps-current-font))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
634 (t
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
635 (format "f%02x-%d" (charset-id charset) ps-current-font)))))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
636 (and func (not font-cache)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
637 (ps-output-prologue (funcall func charset font-spec)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
638 (ps-output-prologue
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
639 (list (format "/%s %f /%s Def%sFontMule\n"
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
640 scaled-font-name font-size font-name
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
641 (if (or header-p
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
642 (eq ps-mule-current-charset 'ascii))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
643 "Ascii" ""))))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
644 (if font-cache
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
645 (setcar (cdr font-cache)
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
646 (cons (cons current-font scaled-font-name)
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
647 (nth 1 font-cache)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
648 (setq font-cache (list font-name
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
649 (list (cons current-font scaled-font-name))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
650 'cache)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
651 ps-mule-font-cache (cons font-cache ps-mule-font-cache)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
652 font-cache))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
653
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
654 (defun ps-mule-generate-glyphs (font-spec code-list)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
655 "Generate PostScript codes which generate glyphs for CODE-LIST of FONT-SPEC."
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
656 (let* ((font-src (ps-mule-font-spec-src font-spec))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
657 (func (nth 5 (assq font-src ps-mule-external-libraries))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
658 (and func
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
659 (ps-output-prologue
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
660 (funcall func font-spec code-list
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
661 (ps-mule-font-spec-bytes font-spec))))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
662
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
663 (defun ps-mule-prepare-font (font-spec string charset
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
664 &optional no-setfont header-p)
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
665 "Generate PostScript codes to print STRING of CHARSET by font FONT-SPEC.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
666
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
667 The generated code is inserted on prologue part except the code that sets the
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
668 current font (using PostScript procedure `FM').
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
669
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
670 If optional 4th arg NO-SETFONT is non-nil, don't generate the code for setting
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
671 the current font.
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
672
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
673 If optional 5th arg HEADER-P is non-nil, generate a code for setting a header
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
674 font."
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
675 (let* ((font-name (ps-mule-font-spec-name font-spec))
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
676 (font-name (if (consp font-name) (car font-name) font-name))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
677 (current-font (+ ps-current-font (if header-p 10 0)))
24086
bedce7fcf0f4 (ps-mule-font-info-database-bdf): Add alternative
Eli Zaretskii <eliz@gnu.org>
parents: 23937
diff changeset
678 (font-cache (assoc font-name ps-mule-font-cache)))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
679 (or (and font-cache (assq current-font (nth 1 font-cache)))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
680 (setq font-cache (ps-mule-generate-font font-spec charset header-p)))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
681 (or no-setfont
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
682 (let ((new-font (cdr (assq current-font (nth 1 font-cache)))))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
683 (or (equal new-font ps-last-font)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
684 (progn
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
685 (ps-output (format "/%s FM\n" new-font))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
686 (setq ps-last-font new-font)))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
687 (if (nth 5 (assq (ps-mule-font-spec-src font-spec)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
688 ps-mule-external-libraries))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
689 ;; We have to generate PostScript codes which define glyphs.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
690 (let* ((cached-codes (nthcdr 2 font-cache))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
691 (bytes (ps-mule-font-spec-bytes font-spec))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
692 (len (length string))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
693 (i 0)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
694 newcodes code)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
695 (while (< i len)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
696 (setq code (if (= bytes 1)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
697 (aref string i)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
698 (+ (* (aref string i) 256) (aref string (1+ i)))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
699 (or (memq code cached-codes)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
700 (progn
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
701 (setq newcodes (cons code newcodes))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
702 (setcdr cached-codes (cons code (cdr cached-codes)))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
703 (setq i (+ i bytes)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
704 (and newcodes
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
705 (ps-mule-generate-glyphs font-spec newcodes))))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
706
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
707 ;;;###autoload
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
708 (defun ps-mule-prepare-ascii-font (string)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
709 "Setup special ASCII font for STRING.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
710 STRING should contain only ASCII characters."
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
711 (let ((font-spec
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
712 (ps-mule-get-font-spec
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
713 'ascii
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
714 (car (nth ps-current-font (ps-font-alist 'ps-font-for-text))))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
715 (and font-spec
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
716 (ps-mule-prepare-font font-spec string 'ascii))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
717
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
718 ;;;###autoload
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
719 (defun ps-mule-set-ascii-font ()
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
720 (unless (eq ps-mule-current-charset 'ascii)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
721 (ps-set-font ps-current-font)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
722 (setq ps-mule-current-charset 'ascii)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
723
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
724 ;; List of charsets of multi-byte characters in a text being printed.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
725 ;; If the text doesn't contain any multi-byte characters (i.e. only ASCII),
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
726 ;; the value is nil.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
727 (defvar ps-mule-charset-list nil)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
728
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
729 ;; This is a PostScript code inserted in the header of generated PostScript.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
730 (defconst ps-mule-prologue
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
731 "%%%% Start of Mule Section
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
732
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
733 %% Working dictionary for general use.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
734 /MuleDict 10 dict def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
735
24721
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
736 %% Adjust /RelativeCompose properly by checking /BaselineOffset.
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
737 /AdjustRelativeCompose { % fontdict |- fontdict
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
738 dup length 2 add dict begin
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
739 { 1 index /FID ne { def } { pop pop } ifelse } forall
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
740 currentdict /BaselineOffset known {
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
741 BaselineOffset false eq { /BaselineOffset 0 def } if
24721
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
742 } {
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
743 /BaselineOffset 0 def
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
744 } ifelse
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
745 currentdict /RelativeCompose known not {
24722
4321a26f6594 fix previous change
Kenichi Handa <handa@m17n.org>
parents: 24721
diff changeset
746 /RelativeCompose [ 0 0.1 ] def
24721
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
747 } {
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
748 RelativeCompose false ne {
27160
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
749 [ BaselineOffset RelativeCompose BaselineOffset add
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
750 [ FontMatrix { FontSize div } forall ] transform ]
1e00f7f6655c ps-vars eliminated, ps-multibyte-buffer now is
Kenichi Handa <handa@m17n.org>
parents: 26882
diff changeset
751 /RelativeCompose exch def
24721
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
752 } if
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
753 } ifelse
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
754 currentdict
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
755 end
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
756 } def
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
757
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
758 %% Define already scaled font for non-ASCII character sets.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
759 /DefFontMule { % fontname size basefont |- --
24721
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
760 findfont exch scalefont AdjustRelativeCompose definefont pop
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
761 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
762
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
763 %% Define already scaled font for ASCII character sets.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
764 /DefAsciiFontMule { % fontname size basefont |-
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
765 MuleDict begin
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
766 findfont dup /Encoding get /ISOLatin1Encoding exch def
24721
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
767 exch scalefont AdjustRelativeCompose reencodeFontISO
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
768 end
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
769 } def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
770
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
771 /CurrentFont false def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
772
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
773 %% Set the specified font to use.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
774 %% For non-ASCII font, don't install Ascent, etc.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
775 /FM { % fontname |- --
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
776 /font exch def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
777 font /f0 eq font /f1 eq font /f2 eq font /f3 eq or or or {
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
778 font F
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
779 } {
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
780 font findfont setfont
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
781 } ifelse
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
782 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
783
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
784 %% Show vacant box for characters which don't have appropriate font.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
785 /SB { % count column |- --
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
786 SpaceWidth mul /w exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
787 1 exch 1 exch { %for
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
788 pop
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
789 gsave
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
790 0 setlinewidth
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
791 0 Descent rmoveto w 0 rlineto
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
792 0 LineHeight rlineto w neg 0 rlineto closepath stroke
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
793 grestore
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
794 w 0 rmoveto
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
795 } for
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
796 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
797
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
798 %% Flag to tell if we are now handling a composition. This is
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
799 %% defined here because both composition handler and bitmap font
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
800 %% handler require it.
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
801 /Composing false def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
802
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
803 %%%% End of Mule Section
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
804
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
805 "
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
806 "PostScript code for printing multi-byte characters.")
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
807
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
808 (defvar ps-mule-prologue-generated nil)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
809
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
810 (defun ps-mule-prologue-generated ()
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
811 (unless ps-mule-prologue-generated
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
812 (ps-output-prologue ps-mule-prologue)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
813 (setq ps-mule-prologue-generated t)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
814
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
815 (defun ps-mule-find-wrappoint (from to char-width &optional composition)
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
816 "Find the longest sequence which is printable in the current line.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
817
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
818 The search starts at FROM and goes until TO.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
819
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
820 Optional 4th arg COMPOSITION, if non-nil, is information of
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
821 composition starting at FROM.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
822
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
823 If COMPOSITION is nil, it is assumed that all characters between FROM
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
824 and TO belong to a charset in `ps-mule-current-charset'. Otherwise,
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
825 it is assumed that all characters between FROM and TO belong to the
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
826 same composition.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
827
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
828 CHAR-WIDTH is the average width of ASCII characters in the current font.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
829
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
830 Returns the value:
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
831
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
832 (ENDPOS . RUN-WIDTH)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
833
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
834 Where ENDPOS is the end position of the sequence and RUN-WIDTH is the width of
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
835 the sequence."
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
836 (if (or composition (eq ps-mule-current-charset 'composition))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
837 ;; We must draw one char by one.
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
838 (let ((run-width (if composition
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
839 (nth 5 composition)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
840 (* (char-width (char-after from)) char-width))))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
841 (if (> run-width ps-width-remaining)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
842 (cons from ps-width-remaining)
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
843 (cons (if composition
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
844 (nth 1 composition)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
845 (ps-mule-next-point from))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
846 run-width)))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
847 ;; We assume that all characters in this range have the same width.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
848 (setq char-width (* char-width (charset-width ps-mule-current-charset)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
849 (let ((run-width (* (chars-in-region from to) char-width)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
850 (if (> run-width ps-width-remaining)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
851 (cons (min to
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
852 (save-excursion
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
853 (goto-char from)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
854 (forward-point
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
855 (truncate (/ ps-width-remaining char-width)))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
856 ps-width-remaining)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
857 (cons to run-width)))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
858
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
859 ;;;###autoload
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
860 (defun ps-mule-plot-string (from to &optional bg-color)
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
861 "Generate PostScript code for plotting characters in the region FROM and TO.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
862
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
863 It is assumed that all characters in this region belong to the same charset.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
864
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
865 Optional argument BG-COLOR specifies background color.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
866
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
867 Returns the value:
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
868
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
869 (ENDPOS . RUN-WIDTH)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
870
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
871 Where ENDPOS is the end position of the sequence and RUN-WIDTH is the width of
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
872 the sequence."
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
873 (setq ps-mule-current-charset (charset-after from))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
874 (let* ((wrappoint (ps-mule-find-wrappoint
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
875 from to (ps-avg-char-width 'ps-font-for-text)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
876 (to (car wrappoint))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
877 (font-type (car (nth ps-current-font
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
878 (ps-font-alist 'ps-font-for-text))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
879 (font-spec (ps-mule-get-font-spec ps-mule-current-charset font-type))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
880 (string (buffer-substring-no-properties from to)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
881 (cond
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
882 ((= from to)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
883 ;; We can't print any more characters in the current line.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
884 nil)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
885
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
886 (font-spec
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
887 ;; We surely have a font for printing this character set.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
888 (ps-output-string (ps-mule-string-encoding font-spec string))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
889 (ps-output " S\n"))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
890
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
891 ((eq ps-mule-current-charset 'latin-iso8859-1)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
892 ;; Latin-1 can be printed by a normal ASCII font.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
893 (ps-output-string (ps-mule-string-ascii string))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
894 (ps-output " S\n"))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
895
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
896 ;; This case is obsolete for Emacs 21.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
897 ((eq ps-mule-current-charset 'composition)
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
898 (ps-mule-plot-composition from (ps-mule-next-point from) bg-color))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
899
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
900 (t
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
901 ;; No way to print this charset. Just show a vacant box of an
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
902 ;; appropriate width.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
903 (ps-output (format "%d %d SB\n"
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
904 (length string)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
905 (if (eq ps-mule-current-charset 'composition)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
906 (char-width (char-after from))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
907 (charset-width ps-mule-current-charset))))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
908 wrappoint))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
909
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
910 ;;;###autoload
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
911 (defun ps-mule-plot-composition (from to &optional bg-color)
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
912 "Generate PostScript code for plotting composition in the region FROM and TO.
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
913
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
914 It is assumed that all characters in this region belong to the same
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
915 composition.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
916
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
917 Optional argument BG-COLOR specifies background color.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
918
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
919 Returns the value:
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
920
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
921 (ENDPOS . RUN-WIDTH)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
922
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
923 Where ENDPOS is the end position of the sequence and RUN-WIDTH is the width of
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
924 the sequence."
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
925 (let* ((composition (find-composition from nil nil t))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
926 (wrappoint (ps-mule-find-wrappoint
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
927 from to (ps-avg-char-width 'ps-font-for-text)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
928 composition))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
929 (to (car wrappoint))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
930 (font-type (car (nth ps-current-font
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
931 (ps-font-alist 'ps-font-for-text)))))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
932 (if (< from to)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
933 ;; We can print this composition in the current line.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
934 (let ((components (nth 2 composition)))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
935 (ps-mule-plot-components
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
936 (ps-mule-prepare-font-for-components components font-type)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
937 (if (nth 3 composition) "RLC" "RBC"))))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
938 wrappoint))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
939
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
940 ;; Prepare font of FONT-TYPE for printing COMPONENTS. By side effect,
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
941 ;; change character elements in COMPONENTS to the form:
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
942 ;; ENCODED-STRING or (FONTNAME . ENCODED-STRING)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
943 ;; and change rule elements to the encoded value (integer).
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
944 ;; The latter form is used if we much change font for the character.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
945
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
946 (defun ps-mule-prepare-font-for-components (components font-type)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
947 (let ((len (length components))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
948 (i 0)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
949 elt)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
950 (while (< i len)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
951 (setq elt (aref components i))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
952 (if (consp elt)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
953 ;; ELT is a composition rule.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
954 (setq elt (encode-composition-rule elt))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
955 ;; ELT is a glyph character.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
956 (let* ((charset (char-charset elt))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
957 (font (or (eq charset ps-mule-current-charset)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
958 (if (eq charset 'ascii)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
959 (format "/f%d" ps-current-font)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
960 (format "/f%02x-%d"
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
961 (charset-id charset) ps-current-font))))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
962 str)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
963 (setq ps-mule-current-charset charset
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
964 str (ps-mule-string-encoding
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
965 (ps-mule-get-font-spec charset font-type)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
966 (char-to-string elt)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
967 'no-setfont))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
968 (if (stringp font)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
969 (setq elt (cons font str) ps-last-font font)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
970 (setq elt str))))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
971 (aset components i elt)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
972 (setq i (1+ i))))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
973 components)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
974
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
975 (defun ps-mule-plot-components (components tail)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
976 (let ((elt (aref components 0))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
977 (len (length components))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
978 (i 1))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
979 (ps-output "[ ")
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
980 (if (stringp elt)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
981 (ps-output-string elt)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
982 (ps-output (car elt) " ")
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
983 (ps-output-string (cdr elt)))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
984 (while (< i len)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
985 (setq elt (aref components i) i (1+ i))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
986 (ps-output " ")
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
987 (cond ((stringp elt)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
988 (ps-output-string elt))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
989 ((consp elt)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
990 (ps-output (car elt) " ")
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
991 (ps-output-string (cdr elt)))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
992 (t ; i.e. (integerp elt)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
993 (ps-output (format "%d" elt)))))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
994 (ps-output " ] " tail "\n")))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
995
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
996 ;; Composite font support
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
997
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
998 (defvar ps-mule-composition-prologue-generated nil)
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
999
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1000 (defconst ps-mule-composition-prologue
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1001 "%%%% Character composition handler
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1002 /RelativeCompositionSkip 0.4 def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1003
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1004 %% Get a bounding box (relative to currentpoint) of STR.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1005 /GetPathBox { % str |- --
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1006 gsave
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1007 currentfont /FontType get 3 eq { %ifelse
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1008 stringwidth pop pop
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1009 } {
24721
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
1010 currentpoint /y exch def /x exch def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1011 false charpath flattenpath pathbbox
24721
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
1012 y sub /URY exch def x sub /URX exch def
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
1013 y sub /LLY exch def x sub /LLX exch def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1014 } ifelse
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1015 grestore
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1016 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1017
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1018 %% Apply effects (underline, strikeout, overline, box) to the
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1019 %% rectangle specified by TOP BOTTOM LEFT RIGHT.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1020 /SpecialEffect { % -- |- --
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1021 currentpoint dup TOP add /yy exch def BOTTOM add /YY exch def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1022 dup LEFT add /xx exch def RIGHT add /XX exch def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1023 %% Adjust positions for future shadowing.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1024 Effect 8 and 0 ne {
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1025 /yy yy Yshadow add def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1026 /XX XX Xshadow add def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1027 } if
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1028 Effect 1 and 0 ne { UnderlinePosition Hline } if % underline
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1029 Effect 2 and 0 ne { StrikeoutPosition Hline } if % strikeout
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1030 Effect 4 and 0 ne { OverlinePosition Hline } if % overline
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1031 bg { % background
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1032 true
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1033 Effect 16 and 0 ne {SpaceBackground doBox} { xx yy XX YY doRect} ifelse
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1034 } if
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1035 Effect 16 and 0 ne { false 0 doBox } if % box
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1036 } def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1037
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1038 %% Show STR with effects (shadow, outline).
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1039 /ShowWithEffect { % str |- --
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1040 Effect 8 and 0 ne { dup doShadow } if
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1041 Effect 32 and 0 ne { true doOutline } { show } ifelse
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1042 } def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1043
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1044 %% Draw COMPONENTS which have the form [ font0? [str0 xoff0 yoff0] ... ].
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1045 /ShowComponents { % components |- -
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1046 LEFT 0 lt { LEFT neg 0 rmoveto } if
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1047 {
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1048 dup type /nametype eq { % font
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1049 FM
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1050 } { % [ str xoff yoff ]
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1051 gsave
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1052 aload pop rmoveto ShowWithEffect
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1053 grestore
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1054 } ifelse
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1055 } forall
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1056 RIGHT 0 rmoveto
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1057 } def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1058
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1059 %% Show relative composition.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1060 /RLC { % [ font0? str0 font1? str1 ... fontN? strN ] |- --
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1061 /components exch def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1062 /Composing true def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1063 /first true def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1064 gsave
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1065 [ components {
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1066 /elt exch def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1067 elt type /nametype eq { % font
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1068 elt dup FM
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1069 } { first { % first string
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1070 /first false def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1071 elt GetPathBox
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1072 %% Bounding box of overall glyphs.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1073 /LEFT LLX def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1074 /RIGHT URX def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1075 /TOP URY def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1076 /BOTTOM LLY def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1077 currentfont /RelativeCompose known {
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1078 /relative currentfont /RelativeCompose get def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1079 } {
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1080 %% Disable relative composition by setting sufficiently low
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1081 %% and high positions.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1082 /relative [ -100000 100000 ] def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1083 } ifelse
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1084 [ elt 0 0 ]
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1085 } { % other strings
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1086 elt GetPathBox
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1087 [ elt % str
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1088 LLX 0 lt { RIGHT } { 0 } ifelse % xoff
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1089 LLY relative 1 get ge { % compose on TOP
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1090 TOP LLY sub RelativeCompositionSkip add % yoff
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1091 /TOP TOP URY LLY sub add RelativeCompositionSkip add def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1092 } { URY relative 0 get le { % compose under BOTTOM
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1093 BOTTOM URY sub RelativeCompositionSkip sub % yoff
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1094 /BOTTOM BOTTOM URY LLY sub sub
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1095 RelativeCompositionSkip sub def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1096 } {
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1097 0 % yoff
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1098 URY TOP gt { /TOP URY def } if
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1099 LLY BOTTOM lt { /BOTTOM LLY def } if
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1100 } ifelse } ifelse
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1101 ]
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1102 URX RIGHT gt { /RIGHT URX def } if
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1103 } ifelse } ifelse
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1104 } forall ] /components exch def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1105 grestore
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1106
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1107 %% Reflect special effects.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1108 SpecialEffect
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1109
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1110 %% Draw components while ignoring effects other than shadow and outline.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1111 components ShowComponents
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1112 /Composing false def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1113
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1114 } def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1115
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1116 %% Show rule-base composition.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1117 /RBC { % [ font0? str0 rule1 font1? str1 rule2 ... strN ] |- --
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1118 /components exch def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1119 /Composing true def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1120 /first true def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1121 gsave
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1122 [ components {
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1123 /elt exch def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1124 elt type /nametype eq { % font
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1125 elt dup FM
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1126 } { elt type /integertype eq { % rule
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1127 %% This RULE decoding should be compatible with macro
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1128 %% COMPOSITION_DECODE_RULE in emacs/src/composite.h.
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1129 elt 12 idiv dup 3 mod /grefx exch def 3 idiv /grefy exch def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1130 elt 12 mod dup 3 mod /nrefx exch def 3 idiv /nrefy exch def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1131 } { first { % first string
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1132 /first false def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1133 elt GetPathBox
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1134 %% Bounding box of overall glyphs.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1135 /LEFT LLX def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1136 /RIGHT URX def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1137 /TOP URY def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1138 /BOTTOM LLY def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1139 /WIDTH RIGHT LEFT sub def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1140 [ elt 0 0 ]
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1141 } { % other strings
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1142 elt GetPathBox
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1143 /width URX LLX sub def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1144 /height URY LLY sub def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1145 /left LEFT [ 0 WIDTH 2 div WIDTH ] grefx get add
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1146 [ 0 width 2 div width ] nrefx get sub def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1147 /bottom [ TOP 0 BOTTOM TOP BOTTOM add 2 div ] grefy get
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1148 [ height LLY neg 0 height 2 div ] nrefy get sub def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1149 %% Update bounding box
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1150 left LEFT lt { /LEFT left def } if
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1151 left width add RIGHT gt { /RIGHT left width add def } if
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1152 /WIDTH RIGHT LEFT sub def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1153 bottom BOTTOM lt { /BOTTOM bottom def } if
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1154 bottom height add TOP gt { /TOP bottom height add def } if
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1155 [ elt left LLX sub bottom LLY sub ]
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1156 } ifelse } ifelse } ifelse
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1157 } forall ] /components exch def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1158 grestore
38855
db1312628833 (find-composition): Check if (char-after POS)
Gerd Moellmann <gerd@gnu.org>
parents: 38816
diff changeset
1159
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1160 %% Reflect special effects.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1161 SpecialEffect
38855
db1312628833 (find-composition): Check if (char-after POS)
Gerd Moellmann <gerd@gnu.org>
parents: 38816
diff changeset
1162
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1163 %% Draw components while ignoring effects other than shadow and outline.
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1164 components ShowComponents
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1165
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1166 /Composing false def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1167 } def
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1168 %%%% End of character composition handler
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1169
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1170 "
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1171 "PostScript code for printing character composition.")
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1172
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1173 (defun ps-mule-string-ascii (str)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1174 (ps-set-font ps-current-font)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1175 (string-as-unibyte (encode-coding-string str 'iso-latin-1)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1176
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1177 ;; Encode STR for a font specified by FONT-SPEC and return the result.
37140
77ab644da66c Fix typo in comment.
Gerd Moellmann <gerd@gnu.org>
parents: 37137
diff changeset
1178 ;; If necessary, it generates the PostScript code for the font and glyphs to
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1179 ;; print STR. If optional 4th arg HEADER-P is non-nil, it is assumed that STR
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1180 ;; is for headers.
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1181 (defun ps-mule-string-encoding (font-spec str &optional no-setfont header-p)
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1182 (let ((encoding (ps-mule-font-spec-encoding font-spec)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1183 (setq str
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1184 (string-as-unibyte
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1185 (cond ((coding-system-p encoding)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1186 (encode-coding-string str encoding))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1187 ((functionp encoding)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1188 (funcall encoding str))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1189 (encoding
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1190 (error "Invalid coding system or function: %s" encoding))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1191 (t
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1192 str))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1193 (if (ps-mule-font-spec-src font-spec)
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1194 (ps-mule-prepare-font font-spec str ps-mule-current-charset
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1195 (or no-setfont header-p)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1196 header-p)
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1197 (or no-setfont
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1198 (ps-set-font ps-current-font)))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1199 str))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1200
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1201 ;; Bitmap font support
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1202
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1203 (defvar ps-mule-bitmap-prologue-generated nil)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1204
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1205 (defconst ps-mule-bitmap-prologue
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1206 "%%%% Bitmap font handler
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1207
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1208 /str7 7 string def % working area
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1209
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1210 %% We grow the dictionary one bunch (1024 entries) by one.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1211 /BitmapDictArray 256 array def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1212 /BitmapDictLength 1024 def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1213 /BitmapDictIndex -1 def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1214
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1215 /NewBitmapDict { % -- |- --
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1216 /BitmapDictIndex BitmapDictIndex 1 add def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1217 BitmapDictArray BitmapDictIndex BitmapDictLength dict put
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1218 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1219
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1220 %% Make at least one dictionary.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1221 NewBitmapDict
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1222
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1223 /AddBitmap { % gloval-charname bitmap-data |- --
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1224 BitmapDictArray BitmapDictIndex get
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1225 dup length BitmapDictLength ge {
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1226 pop
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1227 NewBitmapDict
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1228 BitmapDictArray BitmapDictIndex get
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1229 } if
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1230 3 1 roll put
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1231 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1232
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1233 /GetBitmap { % gloval-charname |- bitmap-data
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1234 0 1 BitmapDictIndex { BitmapDictArray exch get begin } for
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1235 load
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1236 0 1 BitmapDictIndex { pop end } for
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1237 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1238
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1239 %% Return a global character name which can be used as a key in the
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1240 %% bitmap dictionary.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1241 /GlobalCharName { % fontidx code1 code2 |- gloval-charname
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1242 exch 256 mul add exch 65536 mul add 16777216 add 16 str7 cvrs 0 66 put
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1243 str7 cvn
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1244 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1245
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1246 %% Character code holder for a 2-byte character.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1247 /FirstCode -1 def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1248
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1249 %% Glyph rendering procedure
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1250 /BuildGlyphCommon { % fontdict charname |- --
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1251 1 index /FontDimension get 1 eq { /FirstCode 0 store } if
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1252 NameIndexDict exch get % STACK: fontdict charcode
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1253 FirstCode 0 lt { %ifelse
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1254 %% This is the first byte of a 2-byte character. Just
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1255 %% remember it for the moment.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1256 /FirstCode exch store
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1257 pop
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1258 0 0 setcharwidth
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1259 } {
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1260 1 index /FontSize get /size exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1261 1 index /FontSpaceWidthRatio get /ratio exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1262 1 index /FontIndex get exch FirstCode exch
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1263 GlobalCharName GetBitmap /bmp exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1264 %% bmp == [ DWIDTH BBX-WIDTH BBX-HEIGHT BBX-XOFF BBX-YOFF BITMAP ]
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1265 Composing { %ifelse
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1266 /FontMatrix get [ exch { size div } forall ] /mtrx exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1267 bmp 3 get bmp 4 get mtrx transform
24721
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
1268 /LLY exch def /LLX exch def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1269 bmp 1 get bmp 3 get add bmp 2 get bmp 4 get add mtrx transform
24721
25eb63742593 (ps-mule-prologue): Fix the definition of DefFontMule
Kenichi Handa <handa@m17n.org>
parents: 24707
diff changeset
1270 /URY exch def /URX exch def
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1271 } {
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1272 pop
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1273 } ifelse
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1274 /FirstCode -1 store
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1275
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1276 bmp 0 get SpaceWidthRatio ratio div mul size div 0 % wx wy
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1277 setcharwidth % We can't use setcachedevice here.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1278
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1279 bmp 1 get 0 gt bmp 2 get 0 gt and {
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1280 bmp 1 get bmp 2 get % width height
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1281 true % polarity
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1282 [ size 0 0 size neg bmp 3 get neg bmp 2 get bmp 4 get add ] % matrix
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1283 bmp 5 1 getinterval cvx % datasrc
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1284 imagemask
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1285 } if
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1286 } ifelse
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1287 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1288
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1289 /BuildCharCommon {
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1290 1 index /Encoding get exch get
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1291 1 index /BuildGlyph get exec
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1292 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1293
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1294 %% Bitmap font creator
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1295
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1296 %% Common Encoding shared by all bitmap fonts.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1297 /EncodingCommon 256 array def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1298 %% Mapping table from character name to character code.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1299 /NameIndexDict 256 dict def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1300 0 1 255 { %for
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1301 /idx exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1302 /idxname idx 256 add 16 (XXX) cvrs dup 0 67 put cvn def % `C' == 67
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1303 EncodingCommon idx idxname put
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1304 NameIndexDict idxname idx put
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1305 } for
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1306
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1307 /GlobalFontIndex 0 def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1308
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1309 %% fontname dim col fontsize relative-compose baseline-offset fbbx |- --
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1310 /BitmapFont {
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1311 15 dict begin
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1312 /FontBBox exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1313 /BaselineOffset exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1314 /RelativeCompose exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1315 /FontSize exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1316 /FontBBox [ FontBBox { FontSize div } forall ] def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1317 FontBBox 2 get FontBBox 0 get sub exch div
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1318 /FontSpaceWidthRatio exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1319 /FontDimension exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1320 /FontIndex GlobalFontIndex def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1321 /FontType 3 def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1322 /FontMatrix matrix def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1323 /Encoding EncodingCommon def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1324 /BuildGlyph { BuildGlyphCommon } def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1325 /BuildChar { BuildCharCommon } def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1326 currentdict end
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1327 definefont pop
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1328 /GlobalFontIndex GlobalFontIndex 1 add def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1329 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1330
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1331 %% Define a new bitmap font.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1332 %% fontname dim col fontsize relative-compose baseline-offset fbbx |- --
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1333 /NF {
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1334 /fbbx exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1335 %% Convert BDF's FontBoundingBox to PostScript's FontBBox
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1336 [ fbbx 2 get fbbx 3 get
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1337 fbbx 2 get fbbx 0 get add fbbx 3 get fbbx 1 get add ]
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1338 BitmapFont
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1339 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1340
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1341 %% Define a glyph for the specified font and character.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1342 /NG { % fontname charcode bitmap-data |- --
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1343 /bmp exch def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1344 exch findfont dup /BaselineOffset get bmp 4 get add bmp exch 4 exch put
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1345 /FontIndex get exch
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1346 dup 256 idiv exch 256 mod GlobalCharName
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1347 bmp AddBitmap
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1348 } bind def
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1349 %%%% End of bitmap font handler
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1350
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1351 ")
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1352
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1353 ;; External library support.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1354
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1355 ;; The following three functions are to be called from external
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1356 ;; libraries which support bitmap fonts (e.g. `bdf') to get
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1357 ;; appropriate PostScript code.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1358
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1359 (defun ps-mule-generate-bitmap-prologue ()
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1360 (unless ps-mule-bitmap-prologue-generated
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1361 (setq ps-mule-bitmap-prologue-generated t)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1362 (list ps-mule-bitmap-prologue)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1363
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1364 (defun ps-mule-generate-bitmap-font (&rest args)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1365 (list (apply 'format "/%s %d %d %f %S %d %S NF\n" args)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1366
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1367 (defun ps-mule-generate-bitmap-glyph (font-name code dwidth bbx bitmap)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1368 (format "/%s %d [ %d %d %d %d %d <%s> ] NG\n"
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1369 font-name code
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1370 dwidth (aref bbx 0) (aref bbx 1) (aref bbx 2) (aref bbx 3)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1371 bitmap))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1372
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1373 ;; Mule specific initializers.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1374
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1375 ;;;###autoload
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1376 (defun ps-mule-initialize ()
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1377 "Initialize global data for printing multi-byte characters."
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1378 (setq ps-mule-font-cache nil
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1379 ps-mule-prologue-generated nil
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1380 ps-mule-composition-prologue-generated nil
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1381 ps-mule-bitmap-prologue-generated nil)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1382 (mapcar `(lambda (x) (setcar (nthcdr 2 x) nil))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1383 ps-mule-external-libraries))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1384
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1385 (defvar ps-mule-header-charsets nil)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1386
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1387 ;;;###autoload
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1388 (defun ps-mule-encode-header-string (string fonttag)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1389 "Generate PostScript code for ploting STRING by font FONTTAG.
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1390 FONTTAG should be a string \"/h0\" or \"/h1\"."
38816
e4e0e5593284 Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 38436
diff changeset
1391 (setq string (cond ((not (stringp string))
e4e0e5593284 Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 38436
diff changeset
1392 "")
e4e0e5593284 Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 38436
diff changeset
1393 ((multibyte-string-p string)
e4e0e5593284 Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 38436
diff changeset
1394 (copy-sequence string))
e4e0e5593284 Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 38436
diff changeset
1395 (t
e4e0e5593284 Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 38436
diff changeset
1396 (string-make-multibyte string))))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1397 (when ps-mule-header-charsets
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1398 (if (eq (car ps-mule-header-charsets) 'latin-iso8859-1)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1399 ;; Latin1 characters can be printed by the standard PostScript
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1400 ;; font. Converts the other non-ASCII characters to `?'.
37201
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1401 (let ((len (length string))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1402 (i 0))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1403 (while (< i len)
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1404 (or (memq (char-charset (aref string i)) '(ascii latin-iso8859-1))
37201
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1405 (aset string i ??))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1406 (setq i (1+ i)))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1407 (setq string (encode-coding-string string 'iso-latin-1)))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1408 ;; We must prepare a font for the first non-ASCII and non-Latin1
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1409 ;; character in STRING.
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1410 (let* ((ps-current-font (if (string= fonttag "/h0") 0 1))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1411 (ps-mule-current-charset (car ps-mule-header-charsets))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1412 (font-type (car (nth ps-current-font
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1413 (ps-font-alist 'ps-font-for-header))))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1414 (font-spec (ps-mule-get-font-spec ps-mule-current-charset
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1415 font-type)))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1416 (if (or (not font-spec)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1417 (/= (charset-dimension ps-mule-current-charset) 1))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1418 ;; We don't have a proper font, or we can't print them on
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1419 ;; header because this kind of charset is not ASCII
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1420 ;; compatible.
37201
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1421 (let ((len (length string))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1422 (i 0))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1423 (while (< i len)
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1424 (or (memq (char-charset (aref string i))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1425 '(ascii latin-iso8859-1))
37201
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1426 (aset string i ??))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1427 (setq i (1+ i)))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1428 (setq string (encode-coding-string string 'iso-latin-1)))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1429 (let ((charsets (list 'ascii (car ps-mule-header-charsets)))
37201
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1430 (len (length string))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1431 (i 0))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1432 (while (< i len)
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1433 (or (memq (char-charset (aref string i)) charsets)
37201
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1434 (aset string i ??))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1435 (setq i (1+ i))))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1436 (setq string (ps-mule-string-encoding font-spec string nil t))))))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1437 string)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1438
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1439 ;;;###autoload
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1440 (defun ps-mule-header-string-charsets ()
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1441 "Return a list of character sets that appears in header strings."
37201
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1442 (let ((str ""))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1443 (when ps-print-header
37201
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1444 (let ((tail (list ps-left-header ps-right-header)))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1445 (while tail
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1446 ;; Simulate what is done by ps-generate-header-line to get a
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1447 ;; string to plot.
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1448 (let ((count 0)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1449 (tmp (car tail)))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1450 (setq tail (cdr tail))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1451 (while (and tmp (< count ps-header-lines))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1452 (let ((elt (car tmp)))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1453 (setq tmp (cdr tmp)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1454 count (1+ count)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1455 str (concat str
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1456 (cond ((stringp elt) elt)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1457 ((and (symbolp elt) (fboundp elt))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1458 (funcall elt))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1459 ((and (symbolp elt) (boundp elt))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1460 (symbol-value elt))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1461 (t ""))))))))))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1462 (let ((len (length str))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1463 (i 0)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1464 charset-list)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1465 (while (< i len)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1466 (let ((charset (char-charset (aref str i))))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1467 (setq i (1+ i))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1468 (or (eq charset 'ascii)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1469 (memq charset charset-list)
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1470 (setq charset-list (cons charset charset-list)))))
a50c338bd5e7 Eliminate cl package dependence.
Gerd Moellmann <gerd@gnu.org>
parents: 37149
diff changeset
1471 charset-list)))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1472
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1473 ;;;###autoload
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1474 (defun ps-mule-begin-job (from to)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1475 "Start printing job for multi-byte chars between FROM and TO.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1476 This checks if all multi-byte characters in the region are printable or not."
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1477 (setq ps-mule-charset-list nil
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1478 ps-mule-header-charsets nil
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1479 ps-mule-font-info-database
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1480 (cond ((eq ps-multibyte-buffer 'non-latin-printer)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1481 ps-mule-font-info-database-ps)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1482 ((eq ps-multibyte-buffer 'bdf-font)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1483 ps-mule-font-info-database-bdf)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1484 ((eq ps-multibyte-buffer 'bdf-font-except-latin)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1485 ps-mule-font-info-database-ps-bdf)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1486 (t
24707
fded44022dc6 (ps-mule-begin-job): Redo this change "if
Kenichi Handa <handa@m17n.org>
parents: 24415
diff changeset
1487 ps-mule-font-info-database-default)))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1488 (and (boundp 'enable-multibyte-characters)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1489 enable-multibyte-characters
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1490 ;; Initialize `ps-mule-charset-list'. If some characters aren't
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1491 ;; printable, warn it.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1492 (let ((charsets (find-charset-region from to)))
23937
144220e7f841 (ps-mule-begin-job): Programming uniformization.
Kenichi Handa <handa@m17n.org>
parents: 23894
diff changeset
1493 (setq charsets (delq 'ascii (delq 'unknown (delq nil charsets)))
144220e7f841 (ps-mule-begin-job): Programming uniformization.
Kenichi Handa <handa@m17n.org>
parents: 23894
diff changeset
1494 ps-mule-charset-list charsets)
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1495 (save-excursion
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1496 (goto-char from)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1497 (and (search-forward "\200" to t)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1498 (setq ps-mule-charset-list
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1499 (cons 'composition ps-mule-charset-list))))
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1500 ;; We also have to check non-ASCII charsets in the header strings.
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1501 (let ((tail (ps-mule-header-string-charsets)))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1502 (while tail
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1503 (unless (eq (car tail) 'ascii)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1504 (setq ps-mule-header-charsets
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1505 (cons (car tail) ps-mule-header-charsets))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1506 (or (memq (car tail) charsets)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1507 (setq charsets (cons (car tail) charsets))))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1508 (setq tail (cdr tail))))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1509 (while charsets
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1510 (setq charsets
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1511 (cond
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1512 ((or (eq (car charsets) 'composition)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1513 (ps-mule-printable-p (car charsets)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1514 (cdr charsets))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1515 ((y-or-n-p
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1516 "Font for some characters not found, continue anyway? ")
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1517 nil)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1518 (t
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1519 (error "Printing cancelled")))))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1520
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1521 (setq ps-mule-current-charset 'ascii)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1522
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1523 (if (and (nth 2 (find-composition from to))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1524 (not ps-mule-composition-prologue-generated))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1525 (progn
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1526 (ps-mule-prologue-generated)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1527 (ps-output-prologue ps-mule-composition-prologue)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1528 (setq ps-mule-composition-prologue-generated t)))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1529
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1530 (if (or ps-mule-charset-list ps-mule-header-charsets)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1531 (let ((the-list (append ps-mule-header-charsets ps-mule-charset-list))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1532 font-spec elt)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1533 (ps-mule-prologue-generated)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1534 ;; If external functions are necessary, generate prologues for them.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1535 (while the-list
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1536 (setq elt (car the-list)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1537 the-list (cdr the-list))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1538 (cond ((and (eq elt 'composition)
26882
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1539 (not ps-mule-composition-prologue-generated))
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1540 (ps-output-prologue ps-mule-composition-prologue)
5b331ff3b477 Define encode-composition-rule and find-composition
Kenichi Handa <handa@m17n.org>
parents: 26512
diff changeset
1541 (setq ps-mule-composition-prologue-generated t))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1542 ((setq font-spec (ps-mule-get-font-spec elt 'normal))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1543 (ps-mule-init-external-library font-spec))))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1544
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1545 ;; If ASCII font is also specified in ps-mule-font-info-database,
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1546 ;; use it instead of what specified in ps-font-info-database.
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1547 (let ((font-spec (ps-mule-get-font-spec 'ascii 'normal)))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1548 (if font-spec
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1549 (progn
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1550 (ps-mule-prologue-generated)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1551 (ps-mule-init-external-library font-spec)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1552 (let ((font (ps-font-alist 'ps-font-for-text))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1553 (ps-current-font 0))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1554 (while font
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1555 ;; Be sure to download a glyph for SPACE in advance.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1556 (ps-mule-prepare-font (ps-mule-get-font-spec 'ascii (car font))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1557 " " 'ascii 'no-setfont)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1558 (setq font (cdr font)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1559 ps-current-font (1+ ps-current-font)))))))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1560
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1561 ;; If the header contains non-ASCII and non-Latin1 characters, prepare a font
45899
e44f3ea2c30c Fix typo.
Juanma Barranquero <lekktu@gmail.com>
parents: 45334
diff changeset
1562 ;; and glyphs for the first occurrence of such characters.
37137
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1563 (if (and ps-mule-header-charsets
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1564 (not (eq (car ps-mule-header-charsets) 'latin-iso8859-1)))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1565 (let ((font-spec (ps-mule-get-font-spec (car ps-mule-header-charsets)
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1566 'normal)))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1567 (if font-spec
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1568 ;; Be sure to download glyphs for "0123456789/" in advance for page
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1569 ;; numbering.
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1570 (let ((ps-current-font 0))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1571 (ps-mule-prepare-font font-spec "0123456789/" 'ascii t t)))))
b960119b9c18 XEmacs compatibility. Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 30561
diff changeset
1572
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1573 (if ps-mule-charset-list
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1574 ;; We must change this regexp for multi-byte buffer.
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1575 (setq ps-control-or-escape-regexp
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1576 (cond ((eq ps-print-control-characters '8-bit)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1577 "[^\040-\176]")
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1578 ((eq ps-print-control-characters 'control-8-bit)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1579 (string-as-multibyte "[^\040-\176\240-\377]"))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1580 ((eq ps-print-control-characters 'control)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1581 (string-as-multibyte "[^\040-\176\200-\377]"))
25086
799c44a895fe (ps-mule-begin-job): Fix malformed regexp.
Kenichi Handa <handa@m17n.org>
parents: 24722
diff changeset
1582 (t (string-as-multibyte "[^\000-\011\013\015-\377]"))))))
23894
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1583
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1584 ;;;###autoload
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1585 (defun ps-mule-begin-page ()
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1586 (setq ps-mule-current-charset 'ascii))
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1587
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1588
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1589 (provide 'ps-mule)
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1590
f96c37cbdeef New file. Mule related code extracted from
Kenichi Handa <handa@m17n.org>
parents: 23893
diff changeset
1591 ;;; ps-mule.el ends here