-
Notifications
You must be signed in to change notification settings - Fork 6
/
kanji-config-updmap.tex
422 lines (363 loc) · 18.3 KB
/
kanji-config-updmap.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
\documentclass{jlreq}
\usepackage{array}
\usepackage{multicol}
\usepackage{ascmac}
\usepackage{url}
\makeatletter
%%%%%
%
% ptex-fontmaps-data.dat などを読み込んでリストを出力するマクロ
% -- \unless, \readline を使っているので e-TeX 必須
%
% prepare
\newread\xx@myread
%
% main routine
\def\loaddata#1{%
\def\xx@日本語list{}\def\xx@簡体中国語list{}%
\def\xx@繁体中国語list{}\def\xx@韓国語list{}%
% read database
\openin\xx@myread=#1\relax
\@whilesw\unless\ifeof\xx@myread\fi{%
\readline\xx@myread to \xx@dataline
% first: strip trailing LF
\expandafter\xx@striplf\xx@dataline\@nil
\ifx\xx@dataline\@empty\else
% second: strip comments starting from '#'
\expandafter\expandafter\expandafter\xx@stripcomment
\expandafter\xx@dataline\xx@number\@nil
\ifx\xx@dataline\@empty\else
% now, only effective database lines
\expandafter\xx@parseline\xx@dataline\@nil
\fi
\fi
}%
\closein\xx@myread
% output result
\@for\xx@lang:={日本語,簡体中国語,繁体中国語,韓国語}\do{%
\expandafter\let\expandafter\xx@langlist\csname xx@\xx@lang list\endcsname
\ifx\xx@langlist\@empty\else
\begin{itembox}[l]{\xx@lang}
\begin{multicols}{2}
\begin{itemize}
\@for\xx@item:=\xx@langlist\do{\item \command{\xx@item}}%
\end{itemize}
\end{multicols}
\end{itembox}
\fi}
}%
%
% sub
\begingroup
\catcode`\^^M=12 \gdef\xx@lf{^^M}%
\catcode`\#=12 \gdef\xx@number{#}%
\endgroup
\expandafter\def\expandafter\xx@striplf
\expandafter#\expandafter1\xx@lf\@nil{\def\xx@dataline{#1}}
\expandafter\def\expandafter\xx@stripcomment
\expandafter#\expandafter1\xx@number#2\@nil{\def\xx@dataline{#1}}
\def\xx@parseline#1: #2: #3\@nil{\xx@parselang#1\@nil{#2}}
%
% subsub
\begingroup
\escapechar-1
\xdef\xx@JA{\string\JA}\xdef\xx@SC{\string\SC}
\xdef\xx@TC{\string\TC}\xdef\xx@KO{\string\KO}
\xdef\xx@AI{-\string\AI0}
\endgroup
\def\xx@parselang#1#2#3\@nil#4{%
\def\xx@tempa{#1#2}\def\xx@tempb{#3}%
\edef\xx@tempc{#4 \ifx\xx@tempb\xx@AI<AI0>\else#3\fi}%
\ifx\xx@tempa\xx@JA \xx@addtolist\xx@日本語list\xx@tempc \else
\ifx\xx@tempa\xx@SC \xx@addtolist\xx@簡体中国語list\xx@tempc \else
\ifx\xx@tempa\xx@TC \xx@addtolist\xx@繁体中国語list\xx@tempc \else
\ifx\xx@tempa\xx@KO \xx@addtolist\xx@韓国語list\xx@tempc \else
\@latex@error{Unknown language `\xx@tempa' in database}\@ehc
\fi\fi\fi\fi}
\def\xx@addtolist#1#2{%
% #1: name of the list, #2: item
\ifx#1\@empty
\edef#1{#2}%
\else
\edef#1{#1,#2}%
\fi}
%
%%%%%
%
% ptex-fontmaps の README を読み込んでそのまま出力する
% -- \unless, \readline を使っているので e-TeX 必須
%
% main routine
\def\loadprint#1{%
\openin\xx@myread=#1\relax
\@whilesw\unless\ifeof\xx@myread\fi{%
\readline\xx@myread to \xx@dataline
% first: strip trailing LF
\expandafter\xx@striplf\xx@dataline\@nil
% empty line and indent should be kept
\leavevmode\null\xx@dataline\par
}%
\closein\xx@myread
}
%%%%%
\makeatother
%% misc
\def\file#1{\texttt{#1}}
\def\command#1{\texttt{#1}}
\def\option#1{\texttt{-{}-#1}}
\def\codechar#1{\ensuremath{\langle\mbox{\texttt{#1}}\rangle}}
\def\TL{\TeX~Live}
\def\pTeX{p\kern-.15em\TeX}
\def\upTeX{u\pTeX}
\title{\command{kanji-config-updmap} --- 日本語フォント設定ツール}
\author{日本語\TeX 開発コミュニティ}
\begin{document}
\maketitle
\TL に収録されている\file{ptex-fontmaps}パッケージには,
\command{kanji-config-updmap}というコマンドが付属しています。
このコマンドは,\pTeX や\upTeX で生成したDVIを扱う下記のドライバが埋め込む
日本語・中国語・韓国語フォントの設定を統一的に指定したり,
確認したりできます。
\begin{itemize}
\item dvipdfmx(PDFへの埋め込みフォント)
\item dvips(PostScriptで指定するフォント名)
%\item pxdvi(画面表示に使うフォント)\footnote{この機能はオプションです。}
\end{itemize}
\section{はじめに:システム用(\command{-sys})とユーザ用(\command{-user})}
\command{kanji-config-updmap}には2種類のコマンド名があります。
\begin{itemize}
\item \command{kanji-config-updmap-sys}: 全ユーザ向けのシステム共通設定
\item \command{kanji-config-updmap-user}: 現在のユーザ用の設定
\end{itemize}
これは他の「\command{-sys}」と「\command{-user}」の区別のあるコマンドにも
言えることですが,特に理由のない限り,\emph{常に}「\command{-sys}」付きの
コマンド\command{kanji-config-updmap-sys}を使用することをお勧めします。
これは以下の理由によります。
\begin{itemize}
\item 現在のユーザ用の設定は,システム共通設定より優先する。
\item \TL のアップデート時は,システム共通設定は更新されるが,
現在のユーザ用の設定は更新されない。
\item 結果的に,\emph{たった一度でも}「\command{-user}」付きのコマンドを
実行した環境では,\TL のアップデート時に設定更新が反映されない
という事故が起こる。
\end{itemize}
より詳細には,\url{http://tug.org/texlive/scripts-sys-user.html}を参照してください。
なお,「管理者権限がなくて \command{-sys} 付きのコマンドを実行できない」などの
理由がある場合は,\command{kanji-config-updmap-user}を使用してください。
この場合は,\command{tlmgr}で\TL をアップデートすることもない(できない)
でしょうから,上に述べたような不都合は起きないでしょう。
以下では \command{-sys} の方で説明します。
また,Windowsでは\command{sudo}(Unixで管理者権限に昇格するコマンド)を
つける必要はありませんので,\command{sudo}なしに読み替えてください。
\clearpage
\section{現在の埋め込み設定を確認する}
現在の日本語フォントの埋め込み設定を確認するには
\begin{verbatim}
$ sudo kanji-config-updmap-sys --ja status
\end{verbatim}
を実行します。オプション \option{ja} は省略可能で,単に
\begin{verbatim}
$ sudo kanji-config-updmap-sys status
\end{verbatim}
と実行しても同じ結果が得られます\footnote{これは,バージョン20170114.0より
以前に,\command{kanji-config-updmap}が日本語フォント専用だった名残です。}。
同様に,現在の簡体中国語・繁体中国語・韓国語フォントの埋め込み設定はそれぞれ
\begin{verbatim}
$ sudo kanji-config-updmap-sys --sc status
$ sudo kanji-config-updmap-sys --tc status
$ sudo kanji-config-updmap-sys --ko status
\end{verbatim}
で確認できます(オプション \option{sc}, \option{tc}, \option{ko} は省略不可)。
実行例を下に示します。
\begin{verbatim}
$ sudo kanji-config-updmap-sys --ja status
CURRENT family for ja: ipaex (variant: <empty>)
Standby family : haranoaji
Standby family : ipa
Standby family : ms
Standby family : yu-win10
\end{verbatim}
この場合,現在設定されているプリセットは\command{ipaex}であり,
他に4種類のプリセットが利用可能であることを示します。
\command{CURRENT family}の末尾の表示されている
\command{variant}は \command{<empty>} か \command{-04} のいずれかで,
\textbf{JIS90字形とJIS2004字形の両方がサポートされるプリセットでJIS2004字形が
選択されている場合}のみ \command{-04} となります
(第\ref{jis2004}節を参照)。
% kanji-config-updmap 20200217.0 で status に variant も表示するようにした
なお,\TL を公式インストーラでフルインストールすると,デフォルトで
表\ref{tldefault}の設定が適用された状態になります。
それぞれの値が実際にどのフォントに対応しているかは,\file{ptex-fontmaps}の
\file{README}(本PDFの付録\ref{ptex-fontmaps-readme}にも掲載)を参照してください。
例えば,日本語フォントのデフォルト値\command{haranoaji}は
原ノ味フォントに対応しており,さらにデフォルトはJIS2004字形です。
\begin{table}[h]
\centering
\caption{\TL の埋め込みフォントのデフォルト値}\label{tldefault}
\begin{tabular}{m{12zw}m{8zw}}
\hline
変数名(言語) & デフォルト値 \\ \hline
\command{jaEmbed}(日本語) & \command{haranoaji} \\
\command{scEmbed}(簡体中国語) & \command{arphic} \\
\command{tcEmbed}(繁体中国語) & \command{arphic} \\
\command{koEmbed}(韓国語) & \command{baekmuk} \\
\command{jaVariant}(日本語) & \command{-04} \\ \hline
\end{tabular}
\end{table}
\clearpage
\section{日本語フォントの埋め込み設定を変更する}
日本語フォントの埋め込み設定を変更するには
\begin{verbatim}
$ sudo kanji-config-updmap-sys --ja <family>
\end{verbatim}
を実行します。ここでもオプション \option{ja} は省略可能で,単に
\begin{verbatim}
$ sudo kanji-config-updmap-sys <family>
\end{verbatim}
と実行しても同じ結果が得られます。
同様に,現在の簡体中国語・繁体中国語・韓国語フォントの埋め込み設定はそれぞれ
\begin{verbatim}
$ sudo kanji-config-updmap-sys --sc <family>
$ sudo kanji-config-updmap-sys --tc <family>
$ sudo kanji-config-updmap-sys --ko <family>
\end{verbatim}
で変更できます(オプション \option{sc}, \option{tc}, \option{ko} は省略不可)。
なお,オプションの書式は \option{ja <family>} と \option{ja=<family>} のように,
イコール(\command{=})を付けても付けなくても同じ意味になります。
\subsection{利用可能なプリセット一覧}
利用可能な \command{<family>} は以下のとおりです。
実際に対応するフォントは,やはり\file{ptex-fontmaps}の
\file{README}(本PDFの付録\ref{ptex-fontmaps-readme}にも掲載)を参照してください。
このリストで,各値の末尾に付いている \command{(番号)} は,次節で説明する
\command{auto}による自動選択の優先順位を表します。
番号の前の \command{*} については,第\ref{jis2004}節で後述します。
また \command{<AI0>} と付いているものは,Adobe-Identity0の
フォントであることを示し,いくつかの制約事項があります(第\ref{ai0}節)。
\loaddata{database/ptex-fontmaps-data.dat}
さらに,TLContribリポジトリから\file{ptex-fontmaps-macos}パッケージを
インストールすると,以下も追加で利用できます。
\loaddata{database/ptex-fontmaps-macos-data.dat}
複数の言語のフォント埋め込み設定を同時に変更することもできます。例えば
\begin{verbatim}
$ sudo kanji-config-updmap-sys --ja yu-win10 --sc fandol
\end{verbatim}
とすると,日本語フォントを\command{yu-win10}に,
簡体中国語フォントを\command{fandol}に変更します。
設定変更時には,その設定で使われるであろう代表的なフォントファイルが
\emph{実在するかどうかを予めチェック}します(もし実在しなければ,
第\ref{special-preset}節で後述する\command{auto}にフォールバックします)。
オプション \option{force} を付けると,実在するかどうかにかかわらず
強制的にそのプリセットを設定します(バージョン20190506.0の新機能)。
\subsection{日本語フォントのJIS2004字形の使用}\label{jis2004}
一部のプリセットでは,JIS90字形とJIS2004字形の両方をサポートしています。
先ほどのリストで番号の前に \command{*} が\emph{付いていない}プリセットが該当し,
現在すべてのOpenTypeフォントと一部のTrueTypeフォントが含まれます。
これらのプリセットでは,\textbf{デフォルトではJIS90字形が使われます}が,
オプション \option{jis2004} を指定するとJIS2004字形を使用する設定になります。例えば
\begin{verbatim}
$ sudo kanji-config-updmap-sys haranoaji
\end{verbatim}
ではJIS90字形の「原ノ味フォント」が使われますが,
\begin{verbatim}
$ sudo kanji-config-updmap-sys --jis2004 haranoaji
\end{verbatim}
ではJIS2004字形の「原ノ味フォント」が使われます。
一方 \command{*} が\emph{付いている}プリセットでは,
JIS90字形とJIS2004字形の\textbf{どちらが出力されるかはフォント次第}です。
このようなプリセットでは,オプション \option{jis2004} が指定されても
\begin{verbatim}
WARNING: No -04 map available, option --jis2004 ignored!
\end{verbatim}
と警告して無視します。
% 以前はオプションを無視せず -04 のマップファイルを使おうとして,
% 結果的に kanjix.map からマッピングが消えていたが,
% kanji-config-updmap 20200217.0 で --jis2004 を無視する仕様にした
例えば
\begin{verbatim}
$ sudo kanji-config-updmap-sys ipaex
\end{verbatim}
で使われる「IPAexフォント」はJIS2004字形でデザインされています。
\subsection{特殊なプリセット}\label{special-preset}
\emph{フォントを埋め込まない}場合は引数を\command{nofont}とします。
例えば
\begin{verbatim}
$ sudo kanji-config-updmap-sys nofont
\end{verbatim}
とすれば,日本語フォントが埋め込まれません。
また,引数に\command{auto}を指定すると,上記のリストの中から \command{(番号)} が
なるべく小さな\emph{実在するフォント}を自動的に選択します。
ただし,現在設定されている(\command{nofont}以外の)プリセットが
実在していて利用可能な場合は,現在の設定を維持します。
例えば
\begin{verbatim}
$ sudo kanji-config-updmap-sys auto
\end{verbatim}
では日本語フォントが\command{morisawa-pr6n}→\command{morisawa}→…の順に
探され,最初に見つかったフォントを埋め込むように自動で設定されることになります。
\begin{verbatim}
$ sudo kanji-config-updmap-sys --ja auto --sc auto --tc auto --ko auto
\end{verbatim}
とすれば,4つの言語全てが同様に自動設定されます。
\subsection{カスタムプリセットの利用}
[TODO] 作業中。
マップファイルを用意すれば\command{kanji-config-updmap}で設定可能。
\clearpage
\section{特記事項}
まず,一般的な注意点を挙げておきます。
\begin{itemize}
\item 特定の文字が出力されるかどうかは,実際に使われるフォントに依ります。
フォントに収録されていない文字は出力されませんし,
JIS90字形かJIS2004字形のどちらか一方しか用意されていないフォントもあります。
また,組方向専用かな・ルビ用かな(\file{otf}パッケージが提供する機能)に
対応していないフォントもあります\footnote{例えば,\TL~2020以降のデフォルト
日本語フォント\command{haranoaji}は,2022年現在では
組方向専用かなの大半を搭載していますが,ルビ用かなは非搭載であり豆腐となります。}。
% \TL~2019以前のデフォルトであった\command{ipaex}では豆腐にならなかったらしい
\item 複数のウェイトが利用可能かどうかは,プリセットに依ります。
例えば,\command{ipaex}が利用するIPAexフォントは明朝とゴシック
各1ウェイトのみ配布されており,細字の明朝や太字のゴシックは利用できません。
\end{itemize}
その他,いくつかのプリセットには注意点があります。
\subsection{Adobe-Identity0 (AI0)なフォントの制約事項}\label{ai0}
\command{sourcehan}や\command{noto}などを埋め込む設定の注意点です。
[TODO] 作業中。
\begin{itemize}
\item \upTeX~+~dvipdfmx専用です。他の経路(\pTeX~+~dvipdfmx,
\pTeX~+~dvips,\upTeX~+~dvips)はサポートできないため,
\emph{フォントを埋め込まない}設定にフォールバックします。
\item \upTeX~+~dvipdfmxの経路でも,Adobe-Japan1などの従来のマッピングに
依存する文字出力機能もサポートされません。具体的には以下の機能が該当し,
これらの文字も\emph{フォントを埋め込まない}設定にフォールバックします。
\begin{itemize}
\item \file{otf}パッケージが提供する \verb+\CID+ や
\file{ajmacros}(\verb+\aj...+命令など)の大半の命令
\item \file{otf}パッケージ使用時のクオート記号,
つまり\codechar{“}\codechar{”}\codechar{‘}\codechar{’}の4文字
\end{itemize}
\end{itemize}
\subsection{その他}
その他,既知の注意点です。
\file{ptex-fontmaps}はあくまで\pTeX や\upTeX が提供する共通のJFM(\file{ptex-fonts},
\file{uptex-fonts}に収録)から参照される実フォントを切り替えるだけであり,
個別のフォントに対する対処は行っていません。
\begin{itemize}
\item \command{yu}, \command{yu-win10}はWindowsに付属する
TrueType形式の游フォントを埋め込みますが,
クオート記号\codechar{“}\codechar{”}\codechar{‘}\codechar{’}が
全角幅より狭くデザインされているため,出力が異常になります。\\
参考: \url{https://oku.edu.mie-u.ac.jp/tex/mod/forum/discuss.php?d=2017}
\end{itemize}
%\section{内部処理}
%\command{kanji-config-updmap-sys}は内部で\command{updmap-sys}を呼び出し,
%\command{kanji-config-updmap-user}は内部で\command{updmap-user}を呼び出す。
\clearpage
\appendix
\section{\file{ptex-fontmaps}の\file{README}}\label{ptex-fontmaps-readme}
% \readline が和文文字をバイト列に変換しない e-pTeX 190908 以降が必要
% https://github.com/texjporg/tex-jp-build/issues/88
\ifnum\epTeXversion<190908\relax
\errhelp{Update e-pTeX.}\errmessage{e-pTeX 190908 required}
\else
{\frenchspacing\ttfamily\footnotesize\loadprint{README}}
\fi
\end{document}