X-Git-Url: http://git.osdn.jp/view?a=blobdiff_plain;f=doc%2Fluatexja.dtx;h=d9ecfda5eeffa93d91c70c98de3d2b01565872b2;hb=466aee095c5b7d4e8174295dc2cfd5697a87a884;hp=76bb7d251baaa9a8529ff8fc1fcedb1372dfe2cb;hpb=ba775cfe81f4644c17a2934e69bbb9fe14194e9a;p=luatex-ja%2Fluatexja.git diff --git a/doc/luatexja.dtx b/doc/luatexja.dtx index 76bb7d2..d9ecfda 100644 --- a/doc/luatexja.dtx +++ b/doc/luatexja.dtx @@ -1,9 +1,9 @@ %<*!showexpl> %#! lualatex -shell-escape -% \documentclass[a4paper,titlepage]{article} -% \documentclass[a4paper,titlepage]{ltjsarticle} -% \documentclass[a4paper,titlepage]{ltjsarticle} +%\documentclass[a4paper,titlepage]{article} +%\documentclass[a4paper,titlepage]{ltjsarticle} +%\documentclass[a4paper,titlepage]{ltjsarticle} %%%%%%%% \makeatletter @@ -26,14 +26,17 @@ %<*en> \usepackage[margin=25mm,footskip=6mm]{geometry} +\usepackage{luatexja-adjust}\ltjdisableadjust \parskip=\smallskipamount % %<*ja> \usepackage[textwidth=45\zw, lines=45, footskip=6mm]{geometry} +\usepackage{luatexja-adjust}%\ltjdisableadjust \advance\leftmargini-1\zw\advance\leftmarginii-1\zw % %<*zh> \usepackage[textwidth=45\zw, lines=45, footskip=6mm]{geometry} +\usepackage{luatexja-adjust}\ltjdisableadjust \advance\leftmargini-1\zw\advance\leftmarginii-1\zw \def\postpartname{编} \DeclareYokoKanjiEncoding{ZH}{}{} @@ -145,8 +148,8 @@ \DeclareRobustCommand\eTeX{\ensuremath{\varepsilon}-\kern-.125em\TeX} \DeclareRobustCommand\LuaTeX{Lua\TeX} \DeclareRobustCommand\pdfTeX{pdf\TeX} -\DeclareRobustCommand\pTeX{p\kern-.05em\TeX} -\DeclareRobustCommand\upTeX{up\kern-.05em\TeX} +\DeclareRobustCommand\pTeX{p\kern-.15em\TeX} +\DeclareRobustCommand\upTeX{up\kern-.15em\TeX} \DeclareRobustCommand\pLaTeX{p\kern-.05em\LaTeX} \DeclareRobustCommand\pLaTeXe{p\kern-.05em\LaTeXe} \DeclareRobustCommand\epTeX{\ensuremath{\varepsilon}-\kern-.125em\pTeX} @@ -369,12 +372,12 @@ The followings are major changes from \pTeX: %<*en> \item The insertion process of glues/kerns between two Japanese characters and between a Japanese character and other characters - (we refer these glues/kerns as \textbf{JAglue}) is rewritten from + (we refer glues/kerns of both kinds as \textbf{JAglue}) is rewritten from scratch. % %<*ja> -\item 2つの和文文字の間,和文文字と欧文文字の間に入るグルー/カーン - (\textbf{JAglue}と呼ぶ)の挿入処理が0から書き直されている. +\item 2つの和文文字の間や,和文文字と欧文文字の間に入るグルー/カーン + (両者をあわせて\textbf{JAglue}と呼ぶ)の挿入処理が0から書き直されている. % %<*zh> \item 插在日文字符和其他字符言之间的胶/出格(我们将此称为\textbf{JAglue})是重新实现的。 @@ -1502,7 +1505,7 @@ and loads \Pkg{luatexja-fontspec} internally. %<*en> Specifying this option enables us to use \textit{mincho} with two weights (medium~and~bold), \textit{gothic} with three weights (medium,~bold and~heavy), and \textit{rounded gothic}% -\footnote{Provided by \texttt{\char92mgfamily}, +\footnote{Provided by \texttt{\char92mgfamily}, because \textit{rounded gothic} is called \textit{maru gothic} (丸ゴシック) in Japanese.}. The heavy weight of \textit{gothic} can be used by ``changing the family'' \verb+\gtebfamily+. This is because \Pkg{fontspec} package can handle only medium (\verb+\mdseries+) and @@ -1532,25 +1535,25 @@ Use bold gothic as bold mincho. % \item[90jis] %<*en> -Use 90JIS glyphs if possible. +Use fonts with 90JIS glyphs if possible. % %<*ja> -出来る限り90JISの字形を使う. +出来る限り90JISの字形を採用しているフォントを使う. % \item[jis2004] %<*en> -Use JIS2004 glyphs if possible. +Use fonts with JIS2004 glyphs if possible. % %<*ja> -出来る限りJIS2004の字形を使う. +出来る限りJIS2004の字形を採用しているフォントを使う. % \item[jis] %<*en> -Use the JFM \texttt{jfm-jis.lua}, instead of the default JFM of -\LuaTeX-ja, \texttt{jfm-ujis.lua}. +Use the JFM \texttt{jfm-jis.lua}, instead of \texttt{jfm-ujis.lua}, which is the default JFM of +\LuaTeX-ja. % %<*ja> -用いるJFMを\texttt{jfm-jis.lua}とする.このオプションがない時は +用いるJFMを(JISフォントメトリック類似の)\texttt{jfm-jis.lua}にする.このオプションがない時は \LuaTeX-ja標準の\texttt{jfm-ujis.lua}が用いられる. % \end{list} @@ -1618,7 +1621,6 @@ as a substitute for \textit{rounded gothic}. Settings for Hiragino fonts: % %<*ja> -モリサワ・ヒラギノ用の設定はそのようなことは行っていない. まずヒラギノフォントから: % % これらは持っているわけではないので,フォント名が @@ -1707,7 +1709,7 @@ Jun Pro 101&Jun Pr6N 101\\ %<*en> Next, we describe settings for using only single weight. In four settings below, we use same fonts for medium and bold (and heavy) weights. -(Hence \verb+\mcfamily\bfseries+ and \verb+\mcfamily\mdseries+ yields same Japanese fonts, +(Hence \verb+\mcfamily\bfseries+ and \verb+\mcfamily\mdseries+ yields same Japanese fonts, if \texttt{deluxe} option is also specified). % %<*ja> @@ -1892,7 +1894,7 @@ parameters, you have to use commands \verb+\ltjsetparameter+ and %\subsection{Editing the range of \textbf{JAchar}s} %\subsection{\textbf{JAchar}の範囲の設定} %\subsection{\textbf{JAchar}范围设定} - +\label{ssec-setrange} %<*en> To edit the range of \textbf{JAchar}s, you have to assign a non-zero @@ -1913,7 +1915,7 @@ and the character `漢' to the range number~100. 下面就分配了整个表意文字补充平面和汉字“漢”为100。 % \begin{lstlisting} -\ltjdefcharrange{100}{"10000-"1FFFF,`漢} +\ltjdefcharrange{100}{"20000-"2FFFF,`漢} \end{lstlisting} %<*en> This assignment of numbers to ranges are always global, so you should @@ -2120,7 +2122,7 @@ This range consist of the following Unicode ranges, \emph{except characters in t \item \texttt{U+0180}--\texttt{U+024F}: ラテン文字拡張B \item \texttt{U+0250}--\texttt{U+02AF}: IPA拡張(国際音声記号) \item \texttt{U+02B0}--\texttt{U+02FF}: 前進を伴う修飾文字 -\item \texttt{U+0300}--\texttt{U+036F}: ダイアクリティカルマーク(合成可能) +\item \texttt{U+0300}--\texttt{U+036F}: 合成可能な識別記号 \item \texttt{U+1E00}--\texttt{U+1EFF}: ラテン文字拡張追加 % %<*zh> @@ -2140,7 +2142,7 @@ This range consist of the following Unicode ranges, \emph{except characters in t fonts) has some of these characters. % %<*ja> -\item[範囲2${}^{\text{J}}$] ギリシャ文字とキリル文字.JIS~X~0208(したがって多くの +\item[範囲2${}^{\text{J}}$] ギリシャ文字とキリル文字.JIS~X~0208(したがってほとんどの 和文フォント)はこれらの文字を持つ. % %<*zh> @@ -2684,59 +2686,6 @@ xyz漢字 \end{LTXexample} -%\subsection{Cropmark} -%\subsection{トンボ} -%\subsection{裁剪框标记} - -%<*en> -Cropmark is a mark for indicating 4~corners and horizontal/vertical -center of the paper. In Japanese, we call cropmark as tombo(w). -\pLaTeX\ and this \LuaTeX-ja support `tombow' by their kernel. -The following steps are needed to typeset cropmark: -% -%<*ja> -トンボは用紙の四つ角と水平/垂直方向の中心を表す印である. -\pLaTeX と \LuaTeX-jaではトンボの出力をサポートしている. -トンボを出力するためには以下の手順が必要である: -% -%<*zh> -裁剪框标记是在一页的四角和水平/垂直中央放置的标记。在日文中,裁剪框被称为“トンボ”。 -\pLaTeX 和\LuaTeX-ja均在底层支持裁剪框标记。需要下列步骤来实现: -% - -\begin{enumerate} -%<*en> -\item First, define the banner which will be printed at the upper left - of the paper. This is done by assigning a token list to - \verb+\@bannertoken+. - -For example, the following sets banner as `\texttt{filename (YYYY-MM-DD hh:mm)}': -% -%<*ja> -\item まず,用紙の左上に印刷されるバナーを定義する.これは \verb+\@bannertoken+ - にトークンリストを与えることでなされる. - -例えば,以下はバナーとして`\texttt{filename (YYYY-MM-DD hh:mm)}'を設定する: -% -%<*zh> -\item 首先,首先定义页面左上角将会出现的注记。这由向\verb!@bannertoken!分配一个token列完成。\\ -例如,下列所示将会设定注记为“\textsf{filename (YYYY-MM-DD hh:mm)}”: -% - -\begin{verbatim} -\makeatletter - -\hour\time \divide\hour by 60 \@tempcnta\hour \multiply\@tempcnta 60\relax -\minute\time \advance\minute-\@tempcnta -\@bannertoken{% - \jobname\space(\number\year-\two@digits\month-\two@digits\day - \space\two@digits\hour:\two@digits\minute)}% -\end{verbatim} - -\item ... -\end{enumerate} - - %\part{Reference} %\part{リファレンス} %\part{参考指南} @@ -2910,9 +2859,9 @@ JFMの名前を指定する.もし以前に指定されたJFMが読み込ま \toprule &\tt jfm-ujis.lua&\tt jfm-jis.lua&\tt jfm-min.lua\\ \midrule -%Example~1\footnotemark -%例1\footnotemark -%例1\footnotemark +%Example~1\cite{min10} +%例1\cite{min10} +%例1\cite{min10} &\r{ujis}&\r{jis}&\r{min}\\ %Example~2 %例2 @@ -2924,8 +2873,6 @@ Bounding Box&\t{ujis}&\t{jis}&\t{min}\\ \end{center} \ltjsetparameter{jacharrange={-3}} \end{table} -\footnotetext{from: 乙部厳己, min10フォントについて. -\texttt{http://argent.shinshu-u.ac.jp/\~{\ }otobe/tex/files/min10.pdf}.} %\paragraph{Note: kern feature} %\paragraph{注意:kern feature} @@ -3219,13 +3166,16 @@ the following fields: %<*en> This field is a list of characters which are in this character type~$i$. This field is optional if $i=0$, since all - \textbf{JAchar} which are not in any character class other + \textbf{JAchar} which do not belong any character classes other than 0 are in the character class 0 (hence, the character class~0 contains most of - \textbf{JAchar}s). In the list, a character can be - specified by its code number, or by the character itself - (as a string of length~1). Moreover, there are `imaginary - characters' which can be specified in the list. We will describe these later. + \textbf{JAchar}s). In the list, character(s) can be specified in the following form: +\begin{itemize} +\item a Unicode code point +\item the character itself (as a Lua string, like \verb+'あ'+) +\item a string like \verb+'あ*'+ (the character followed by an asterisk) +\item several ``imaginary'' characters (We will describe these later.) +\end{itemize} % %<*ja> このフィールドは文字クラス$i$に属する文字のリストである.このフィールドは$i=0$の @@ -3428,9 +3378,48 @@ Furthermore, the glyph is shifted according to values of fields \label{fig-pos} \end{figure} -\item[kern={\{[$j$]=, ...\}}] +\item[kern={\{[$j$]=, [$j'$]=\{, []\}...\}}] + +\item[glue={\{[$j$]=\{, , , [], []\}, ...\}}] +%<*ja> +文字クラス$i$の文字と$j$の文字の間に挿入されるkernやglueの量を指定する. + + は\texttt{luatexja-adjust.sty} による優先順位付き + 行長調整(\ref{ssec-adj}節)が有効なときのみ意味を持つ. +このフィールドは省略可能であり,行調整処理におけるこのglueの優先 + 度を$-2$から$+2$の間の整数で指定する.の省略時の値 + は0であり,範囲外の値が指定されたときの動作は未定義である). + +も省略可能フィールドであり,$-1$から$+1$の実数値をとる.省略時の値は0である. +\begin{itemize} +\item $-1$はこのグルーが「前の文字」由来であることを示す. +\item $+1$はこのグルーが「後の文字」由来であることを示す. +\item それ以外の値は,「前の文字」由来のグルーと「後の文字」由来の +グルーが混合されていることを示す. +\end{itemize} +なお,このフィールドの値は\Param{differentjfm}の値が\texttt{pleft},~\texttt{pright},~\texttt{paverage}の値のときのみ実際に用いられる. + +例えば,\cite{x4051}では,句点と中点の間には, +句点由来の二分空きと中点由来の四分空きが挿入されるが,この場合には +\begin{itemize} +\item には$0.5+0.25=0.75$を指定する. +\item には次の値を指定する. +\[ + -1\cdot \frac{0.5}{0.5+0.25} + 1 \cdot \frac{0.25}{0.5+0.25} = -\frac13 +\] +\end{itemize} + +% + +\item[end\_stretch=] +\item[end\_shrink=] +%<*ja> +これらのフィールドは省略可能である. +優先順位付き行長調整が有効であり,かつ現在の文字クラスの文字が行 + 末に来た時に,行長を詰める調整・伸ばす調整のた + めにこの文字と行末の間に挿入可能なカーンの大きさを指定する. +% -\item[glue={\{[$j$]=\{, , \}, ...\}}] \end{list} %<*ja> @@ -3441,7 +3430,7 @@ Furthermore, the glyph is shifted according to values of fields たとえば,次の内容を一部に含んだ \texttt{jfm-test.lua} を考えよう: \begin{lstlisting} [0] = { - chars = { '漢', 'ヒ*' }, + chars = { '漢', 'ヒ*' }, align = 'left', left = 0.0, down = 0.0, width = 1.0, height = 0.88, depth = 0.12, italic=0.0, }, @@ -3512,15 +3501,15 @@ The following is the list of `imaginary characters': 下列为“假想字符”列表: % \begin{list}{}{\def\makelabel{\ttfamily}\def\{{\char`\{}\def\}{\char`\}}\advance\leftmargin1\zw} -\item['lineend'] -%An ending of a line. -%行の終端を表す. -%行尾结束字符。 +%%\item['lineend'] +%%%An ending of a line. +%%%行の終端を表す. +%%%行尾结束字符。 -\item['diffmet'] -%Used at a boundary between two \textbf{JAchar}s whose JFM or size is different. -%JFMやサイズが異なる2つの\textbf{JAchar}の間の境界として用いられる. -%用于两个不同大小或不同JFM的两个\textbf{JAchar}间边界。 +%%\item['diffmet'] +%%Used at a boundary between two \textbf{JAchar}s whose JFM or size is different. +%%JFMやサイズが異なる2つの\textbf{JAchar}の間の境界として用いられる. +%%用于两个不同大小或不同JFM的两个\textbf{JAchar}间边界。 \item['boxbdd'] %The beginning/ending of a horizontal box, and the beginning of a noindented paragraph. @@ -3707,7 +3696,7 @@ this argument has \texttt{chars} field which contains character codes %<*en> An example of this callback is the \texttt{ltjarticle} class, with forcefully assigning character class~0 to \texttt{'parbdd'} - in the JFM \texttt{jfm-min.lua}. + in the JFM \texttt{jfm-min.lua}. % %<*ja> このコールバックの使用例は\texttt{ltjarticle}クラスにあり, @@ -3757,7 +3746,19 @@ You may assume that \verb+jfont_info+ has the following fields: \item \texttt{dir} フィールドはこのテーブルにはない. \end{itemize} % -% ... +%<*en> +A table which contains the information of a JFM, and \emph{this table must not be changed}. +The contents of this table are similar to that which is written is the JFM file, but +the following differ: +\begin{itemize} +\item There is a \texttt{chars} table, \dots +\item The value in \texttt{zw},~\texttt{zh}, \texttt{kanjiskip},~\texttt{xkanjiskip} fields are +now scaled by real font size, and in scaled-pont unit. +\item ... +\item There is no \texttt{dir} field in this table. +\end{itemize} +% +% ... \item[\tt var] %The value specified in \texttt{jfmvar=...} at a call of \verb+\jfont+. @@ -4175,6 +4176,9 @@ JFM(もしくはサイズ)が異なる2つの\textbf{JAchar}の間にグル \item[\texttt{both}] \item[\texttt{large}] \item[\texttt{small}] +\item[\texttt{pleft}] +\item[\texttt{pright}] +\item[\texttt{paverage}] \end{description} \item[\Param{jacharrange}\,=$^\ast$] @@ -4190,7 +4194,8 @@ JFM(もしくはサイズ)が異なる2つの\textbf{JAchar}の間にグル %\subsection{基本语句兼容性} %<*en> -The following primitives are implemented for compatibility with \pTeX: +The following primitives are implemented for compatibility with \pTeX. +Note that these primitives don't support JIS~X~0213, but only JIS~X~0208. % %<*ja> 以下のプリミティブは\pTeX との互換性のために実装されている: @@ -4266,8 +4271,9 @@ With the help of this example, we remark the specification of \verb+\inhibitglue %<*ja> \item \verb+\inhibitglue+ の(制限された)水平モード中での呼び出しはその場でのみ 有効であり,段落の境界を乗り越えない. - さらに,\verb+\inhibitglue+ は上の例の最終行のようにリガチャとカーニングを - 打ち消す. + さらに,\verb+\inhibitglue+ は上の例の最終行のように(欧文における)リガチャとカーニングを + 打ち消す.これは,\verb+\inhibitglue+ が内部的には「現在のリスト中にwhatsitノードを + 追加する」ことを行なっているからである. % %<*en> @@ -4471,19 +4477,15 @@ As closing this subsection, we shall introduce an example of % %<*ja> この節の終わりに,\verb+\SetRelationFont+ と \verb+\userelfont+ の例を -紹介しておこう. +紹介しておこう.\verb+\userelfont+ の使用によって,「abc」の部分のフォントが +Avant Garde (OT1/pag/m/n) に変わっていることがわかる. % \begin{LTXexample} -\gtfamily{}あいうabc +\kanjifamily{gt}\selectfont あいうxyz \SetRelationFont{JY3}{gt}{m}{n}{OT1}{pag}{m}{n} -\userelfont\selectfont{}あいうabc +\userelfont\selectfont あいうabc \end{LTXexample} - -%\subsection{Cropmark/`tombow'} -%\subsection{トンボ} -% ToDo - %\section{Extensions} %\section{拡張} \subsection{\texttt{luatexja-fontspec.sty}} @@ -4520,7 +4522,9 @@ See Subsections~\ref{ssec-jfont} and \ref{ssec-psft} for details. これら3つのキーはそれぞれ \verb+\jfont+ プリミティブに対する \texttt{cid}, \texttt{jfm}, \texttt{jfmvar}キーとそれぞれ対応する. \texttt{CID} は下の \texttt{NoEmbed} と合わせて用いられたときのみ有効である. -詳細は\ref{ssec-jfont}節と\ref{ssec-psft}節を参照. +\verb+\jfont+ プリミティブに対する +\texttt{cid}, \texttt{jfm}, \texttt{jfmvar}キーの詳細は\ref{ssec-jfont}節 + と\ref{ssec-psft}節を参照. % \item[NoEmbed] @@ -4613,6 +4617,83 @@ JFMの\texttt{chars}テーブルのエントリとして \verb+'AJ1-xxx'+ の形 使えるようになる.これはAdobe-Japan1におけるCID番号が \verb+xxx+ の文字を表す. % +\subsection{\texttt{luatexja-adjust.sty}} +\label{ssec-adj} +\begin{figure}[t] +\def\sq{% + \hbox to 1\zw{\hss\fboxsep=-.5\fboxrule\fbox{% +  \hskip\dimexpr-.5\zw-.2pt\vrule width.4pt height.08\zw depth.12\zw% + \hskip\dimexpr.5\zw-.2pt\relax}\hss}} +\def\sb{\hbox to 1\zw{\hss\fboxsep=-.5\fboxrule\fbox{% + ■\hskip\dimexpr-.5\zw-.2pt\vrule width.4pt height.08\zw depth.12\zw% + \hskip\dimexpr.5\zw-.2pt\relax}\hss}} +\newbox\gridbox +\def\outbox#1{{\Large% + \ltjsetparameter{kanjiskip=0pt plus .2\zw minus .2\zw}% + \setbox\gridbox=\hbox to 20\zw{\sq\sq\sq\sq\sb\sq\sq\sq\sq\sb\sq\sq\sq\sq\sb\sq\sq\sq\sq\sb}% + \hbox{\textcolor{cyan!50!white}{\copy\gridbox}\hskip-20\zw% + \vbox{\hsize=20\zw\noindent\leftskip0pt\rightskip0pt\parfillskip0pt#1}\vrule}% +}} + +{\centering +\begin{tabular}{lc} +\toprule +no adjustment&\outbox{以上の原理は,「包除原理」とよく呼ばれるが\hskip-.5\zw\null}\\ +without priority&% +\ltjdisableadjust +\outbox{以上の原理は,「包除原理」とよく呼ばれるが}% +\ltjenableadjust\\ +with priority&% +\outbox{以上の原理は,「包除原理」とよく呼ばれるが} +%\ltjdisableadjust +\\ +\bottomrule +\end{tabular}\par} +\smallskip + +Note: the value of +\Param{kanjiskip} is 0\,pt${}^{+1/5\,\mathrm{em}}_{-1/5\,\mathrm{em}}$ in this figure, +for making the difference obvious. +%\caption{行長調整}\label{fig-adj} +%\caption{Line adjustment}\label{fig-adj} +\end{figure} + + +%<*en> +... +% +%<*ja> +\pTeX では,行長調整において優先度の概念が存在しなかったため,図 +\ref{fig-adj}上段における半角分の半端は,図\ref{fig-adj}中段のように,鍵 +括弧周辺の空白と和文間空白(\Param{kanjiskip})の両方によって負担される.し +かし,「日本語組版処理の要件」\cite{jlreq}やJIS~X~4051~\cite{x4051}におい +ては,このような状況では半端は鍵括弧周辺の空白のみで負担し,その他の和文 +文字はベタ組で組まれる(図\ref{fig-adj}下段)ことになっている.この追加 +パッケージは\cite{jlreq}や\cite{x4051}における規定のような,優先順位付き +の行長調整を提供する.詳細な仕様については\ref{sec-adjspec}を参照. + + +\texttt{luatexja-adjust.sty}は,以下の命令を提供する.これらはすべてグローバルに効力を発揮する. + +\begin{list}{}{\def\makelabel{\ttfamily}\def\{{\char`\{}\def\}{\char`\}}\advance\leftmargin1\zw} +\item[\char92ltjdisableadjust] +優先順位付きの行長調整を無効化する. + +\item[\char92ltjenableadjust] +優先順位付きの行長調整を有効化する. + +\item[優先度設定……] + +\end{list} + + + + + +% + + + %\part{Implementations} %\part{実装} \label{part-imp} @@ -4761,7 +4842,7 @@ Penalties inserted for the word-wrapping process of Japanese characters (\emph{k 和文文字のワードラップ過程において挿入されたペナルティ(\emph{kinsoku}). % -\item[\textit{from\_jfm} (4)] +\item[\textit{from\_jfm} (6)] %<*en> Glues/kerns from JFM. % @@ -4769,16 +4850,16 @@ Glues/kerns from JFM. JFM由来のグルー/カーン. % -\item[\textit{line\_end} (5)] -%<*en> -Kerns for \ldots -% -%<*ja> -和文文字が行末にきたとき,行末との間に挿入されるカーンである. -% ぶら下げ組への応用 -% +%%\item[\textit{line\_end} (5)] +%%%<*en> +%%Kerns for \ldots +%%% +%%%<*ja> +%%和文文字が行末にきたとき,行末との間に挿入されるカーンである. +%%% ぶら下げ組への応用 +%%% -\item[\textit{kanji\_skip} (6)] +\item[\textit{kanji\_skip} (9)] %<*en> Glues for \Param{kanjiskip}. % @@ -4786,7 +4867,7 @@ Glues for \Param{kanjiskip}. \Param{kanjiskip}のグルー. % -\item[\textit{xkanji\_skip} (7)] +\item[\textit{xkanji\_skip} (10)] %<*en> Glues for \Param{xkanjiskip}. % @@ -4794,7 +4875,7 @@ Glues for \Param{xkanjiskip}. \Param{xkanjiskip}のグルー. % -\item[\textit{processed} (8)] +\item[\textit{processed} (11)] %<*en> Nodes which is already processed by \ldots. % @@ -4802,7 +4883,7 @@ Nodes which is already processed by \ldots. \LuaTeX-ja の内部処理によって既に処理されたノード. % -\item[\textit{ic\_processed} (9)] +\item[\textit{ic\_processed} (12)] %<*en> Glues from an italic correction, but also already processed. % @@ -5184,19 +5265,19 @@ after `beginning/ending of a group' characters. \item[\textsf{5}] \textit{end-of-line} (usually \verb+^^J+). \item[\textsf{10}] space (usually \sp). \item[\textsf{O}] other characters, whose category code is in $\{3,4,6,7,8,11,12,13\}$. -\item[\textsf{[\sp]}, \textsf{[{\tt\char92par}]}] +\item[\textsf{[\sp]}, \textsf{[{\tt\char92par}]}] emits a space, or~\verb+\par+. \end{description} \end{minipage} \begin{itemize} -\item We omitted about category codes +\item We omitted about category codes 9~(\textit{ignored}), 14~(\textit{comment})~and~15~(\textit{invalid}) from the above diagram. We also ignored the input like `\verb+^^A+' or `\verb+^+\verb+^df+'. -\item When a character whose category code is 0 (\textit{escape character}) is seen by \TeX, -the input processor scans a control sequence (\textsf{scan a c.s.}). +\item When a character whose category code is 0 (\textit{escape character}) is seen by \TeX, +the input processor scans a control sequence (\textsf{scan a c.s.}). These paths are not shown in the above diagram. -After that, the state is changed to State~$S$ (skipping blanks) in most cases, but +After that, the state is changed to State~$S$ (skipping blanks) in most cases, but to State~$M$ (middle of line) sometimes. \end{itemize} %\caption{State transitions of \pTeX's input processor.} @@ -5318,7 +5399,7 @@ u %\subsection{概要} %\subsection{概要} -\LuaTeX-jaにおける和文処理グルーの挿入方法は,\pTeX のそれとは全く異なる. +\LuaTeX-jaにおける \textbf{JAglue} の挿入方法は,\pTeX のそれとは全く異なる. \pTeX では次のような仕様であった: \begin{itemize} \item JFMグルーの挿入は,和文文字を表すトークンを元に水平リストに(文字を表す)を @@ -5610,19 +5691,54 @@ $g$は「文字コード\texttt{'boxbdd'}の文字」と\textit{Np}の間に入 \item もし両クラスタの間で\verb+\inhibitglue+が実行されていた場合(証としてwhatsitノードが自動挿入される), 代わりに\Param{kanjiskip}が挿入されることとなる.次へ. \item \textit{Nq}と\textit{Np}が同じJFM・同じ\texttt{jfmvar}キー・同じサイズの和文フォントであったならば, - 共通に使っているJFM内で挿入される空白(グルーかカーン)が決まっているか調べる. + 共通に使っているJFM内で挿入される空白(グルーかカーン)が決まっているか調べ,決まっていればそれを採用. \item 1.でも2.でもない場合は,\textit{Nq}と\textit{Np}が違うJFM/\texttt{jfmvar}/サイズである. この場合,まず \[ -\vcenter{\halign{\hfil$#:={}$&(\inhibitglue#\inhibitglue)\cr -gb&\textit{Nq}と「文字コードが{\tt'diffmet'}の文字」との間に入るグルー/カーン\cr -ga&「文字コードが{\tt'diffmet'}の文字」と\textit{Np}との間に入るグルー/カーン\cr +\vcenter{\halign{\hfil$#:={}$&\inhibitglue#\inhibitglue\cr +gb&(\textit{Nq}と「使用フォントが\textit{Nq}のそれと同じで,\hfil\cr +\omit&\quad 文字コードが\textit{Np}のそれの文字」との間に入るグルー/カーン)\hfil\cr +ga&(\inhibitglue 「使用フォントが\textit{Np}のそれと同じで,\hfil\cr +\omit&\quad 文字コードが\textit{Nq}のそれの文字」と\textit{Np}との間に入るグルー/カーン)\hfil\cr }} \] -として,左側由来・右側由来の空白(グルー/カーン)を(それぞれのJFMから)求める. -$\mathit{ga}$と$\mathit{gb}$のどちらか片方が未定義であるならば,定義されている側の値をそのまま採用する. -もし$\mathit{ga}$と$\mathit{gb}$が両方決まっているならば,両者の値を平均\footnote{\Param{differentjfm}パラメタの -値によって,「大きい方」「小さい方」「合計」に変えることができる.}した値を採用する. +として,前側の文字のJFMを使った時の空白(グルー/カーン)と,後側の文字のJFMを使った時のそれを求める. + +$\mathit{gb}$,~$\mathit{ga}$それぞれに対するの値を$d_b$,~$d_a$とする. +\begin{itemize} +\item +$\mathit{ga}$と$\mathit{gb}$の両方が未定義であるならば,JFM由来のグルーは挿入されず,\Param{kanjiskip}を採用することとなる.どちらか片方のみが未定義であるならば,次のステップでその未定義の方は長さ0のkernで,の値は0であるかのように扱われる. +\item +\Param{differentjfm}の値が\texttt{pleft}, \texttt{pright}, \texttt{paverage}のとき, +の指定に従って比例配分を行う. +JFM由来のグルー/カーンは以下の値となる: +\[ + f\left(\frac{1-d_b}2\textit{gb} + \frac{1+d_b}2\textit{ga}, +\frac{1-d_a}2\textit{gb} + \frac{1+d_a}2\textit{ga}\right) +\] +ここで.$f(x,y)$は +\[ + f(x,y)=\begin{cases} +x&\text{if\ }\Param{differentjfm}=\texttt{pleft};\\ +y&\text{if\ }\Param{differentjfm}=\texttt{pright};\\ +(x+y)/2&\text{if\ }\Param{differentjfm}=\texttt{paverage}; +\end{cases}. +\] +\item +\Param{differentmet}がそれ以外の値の時は,の値は無視され,JFM由来のグルー/カーンは以下の値となる: +\[ + f(\textit{gb},\textit{ga}) +\] +ここで.$f(x,y)$は +\[ + f(x,y)=\begin{cases} +\min(x,y)&\text{if\ }\Param{differentjfm}=\texttt{small};\\ +\max(x,y)&\text{if\ }\Param{differentjfm}=\texttt{large};\\ +(x+y)/2&\text{if\ }\Param{differentjfm}=\texttt{average};\\ +x+y&\text{if\ }\Param{differentjfm}=\texttt{both}; +\end{cases}. +\] +\end{itemize} \end{enumerate} 例えば, @@ -5655,18 +5771,19 @@ JFM由来の値だけを用いる.もし両者で使われているJFMが異 \end{enumerate} \end{description} \paragraph{「左空白」の算出とそれに伴う補正} -次に,「左空白」にあたる量を算出する: -\begin{description} -\item[line-end~{[E]}] -\textit{Nq}と\textit{Np}の間で行分割が起きたときに, -\textit{Nq}と行末の間に入る空白である.ぶら下げ組の組版などに用いられることを期待している. -\begin{enumerate} -\item 既に算出した「右空白」がカーンである場合は,「左空白」は挿入されない. -\item 「右空白」がglueか未定義(長さ0のglueとみなす)の場合は,「左空白」は -\textit{Nq}と「文字コード\texttt{'lineend'}の文字」との間に入るカーンとして,JFMから決定される. -\item 2.で決まった「左空白」の長さが0でなければ,その分だけ先ほど算出した「右空白」の自然長を引く. -\end{enumerate} -\end{description} +「左空白」は過去のバージョンでは定義していたが,このバージョンでは挿入は一切行われない(機能自体削除している).しかし,仕様は流動的であり,将来復活する可能性もあるため,マニュアル中の記述は今のところ極力変更しない. +% 次に,「左空白」にあたる量を算出する: +% \begin{description} +% \item[line-end~{[E]}] +% \textit{Nq}と\textit{Np}の間で行分割が起きたときに, +% \textit{Nq}と行末の間に入る空白である.ぶら下げ組の組版などに用いられることを期待している. +% \begin{enumerate} +% \item 既に算出した「右空白」がカーンである場合は,「左空白」は挿入されない. +% \item 「右空白」がglueか未定義(長さ0のglueとみなす)の場合は,「左空白」は +% \textit{Nq}と「文字コード\texttt{'lineend'}の文字」との間に入るカーンとして,JFMから決定される. +% \item 2.で決まった「左空白」の長さが0でなければ,その分だけ先ほど算出した「右空白」の自然長を引く. +% \end{enumerate} +% \end{description} \paragraph{禁則用ペナルティの挿入} まず, \[ @@ -5960,38 +6077,419 @@ $\mathit{Nq}.\mathit{tail}$は無意味なので, \section{psft} +%\section{Patch for the \Pkg{listings} package} +%\section{\Pkg{listings} パッケージへの対応} + +%<*en> +It is well-known that the \Pkg{listings} package outputs weird results +for Japanese input. +The \Pkg{listings} package makes most of letters active and assigns +output command for each letter \cite{listings}. +But Japanese characters are not included in these activated letters. +For \pTeX{} series, there is no method to make Japanese characters active; +a patch \Pkg{jlisting.sty} \cite{jlisting} resolves the problem forcibly. +% +%<*ja> +\Pkg{listings} パッケージが,そのままでは日本語をまともに出力できないこと +はよく知られている.きちんと整形して出力するために,\Pkg{listings}パッケー +ジは内部で「ほとんどの文字」をアクティブにし,各文字に対してその文字の出 +力命令を割り当てている \cite{listings}. +しかし,そこでアクティブにする文字の中に,和文文 +字がないためである.\pTeX 系列では,和文文字をアクティブにする手法がなく, +\Pkg{jlisting.sty} というパッチ\cite{jlisting}を用いることで無理やり解決していた. +% + +%<*en> +In \LuaTeX-ja, the problem is resolved by using \verb+process_input_buffer+ callback. +The callback function inserts the output command before each letter above U+0080. +This method can omits the process to make all Japanese characters active +(most of the activated characters are not used in many cases). +% +%<*ja> +\LuaTeX-jaでは,\verb+process_input_buffer+ コールバックを利用することで, +「各行に出現するU+0080以降の文字に対して,それらの出力命令を前置する」という方法をとっている. +これにより,(入力には使用されていないかもしれない)和文文字をもすべてアクティブ化する手間もなく, +見通しが良い実装になっている. +% + +%<*en> +If \Pkg{listings.sty} and \LuaTeX-ja were loaded, +then the patch \Pkg{lltjp-listings.sty} is loaded automatically at \verb+\begin{document}+. +% +%<*ja> +\LuaTeX-ja で利用される \Pkg{listings} パッケージへのパッチ \Pkg{lltjp-listings.sty} は, +\Pkg{listings.sty} と\LuaTeX-jaを読み込んでおけば, +\verb+\begin{document}+ の箇所において自動的に読み込まれるので,通常はあまり +意識する必要はない. +% + +%\paragraph{Class of characters} +%\paragraph{文字種} + +%<*en> +Roughly speaking, the \Pkg{listings} package processes input as follows: +% +%<*ja> +\Pkg{listings} パッケージの内部では,大雑把に言うと +% +\begin{enumerate} +%<*en> +\item Collects \textit{letters} and \textit{digits}, which can be used for the name of identifiers. +% +%<*ja> +\item 識別子として使える文字 (``letter'',~``digit'') たちを +集める. +% + +%<*en> +\item When reading an \textit{other}, outputs the collected character string (with modification, if needed). +% +%<*ja> +\item letterでもdigitでもない文字が現れた時に,収集した文字列を(必要なら修飾して)出力する. +% + +%<*en> +\item Collects \textit{others}. +% +%<*ja> +\item 今度は逆に,letterでない文字たちをletterが現れるまで集める. +% + +%<*en> +\item When reading a \textit{letter} or a \textit{digit}, outputs the collected character string. +% +%<*ja> +\item letterが出現したら集めた文字列を出力する. +% + +%<*en> +\item Turns back to 1. +% +%<*ja> +\item 1.に戻る. +% +\end{enumerate} +%<*en> +By the above process, line breaks inside of an identifier are blocked. +A flag \verb+\lst@ifletter+ indicates whether the previous character can be used +for the name of identifiers or not. +% +%<*ja> +という処理が行われている.これにより,識別子の途中では行分割が行われないようになっている. +直前の文字が識別子として使えるか否かは \verb+\lst@ifletter+ というフラグに格納されている. +% + +%<*en> +For Japanese characters, line breaks are permitted on both sides +except for parentheses, dashes, etc. +To process Japanese characters, +The pacth \Pkg{lltjp-listings.sty} introduces a new flag \verb+\lst@ifkanji+, which indicates +whether the previous character is Japanese character or not. +For illustration, we introduce the following classes of character: +% +%<*ja> +さて,日本語の処理である.殆どの和文文字の前後では行分割が可能であるが,その一方で +括弧類や音引きなどでは禁則処理が必要なことから,\Pkg{lltjp-listings.sty} では, +直前が和文文字であるかを示すフラグ \verb+\lst@ifkanji+ を新たに導入した. +以降,説明のために以下のように文字を分類する: +% +\begin{center} +\small +\begin{tabular}{lccccc} +\toprule +&Letter&Other&Kanji&Open&Close\\\midrule +\verb+\lst@ifletter+&T&F&T&F&T\\ +\verb+\lst@ifkanji+&F&F&T&T&F\\ +%Meaning&identifier char&other alphabet&most of Japanese char&open paren&close paren\\ +%意図&識別子中の文字&その他欧文文字&殆どの和文文字&開き括弧類&閉じ括弧類\\ +\bottomrule +\end{tabular} +\end{center} +%<*en> +Note that \textit{digits} in the \Pkg{listings} package can be Letter or +Other according to circumstances. +% +%<*ja> +なお,本来の\Pkg{listings} パッケージでの分類``digit''は, +出現状況によって,上の表のLetterとOtherのどちらにもなりうる. +また,KanjiとCloseは \verb+\lst@ifletter+ と \verb+\lst@ifkanji+ の値が一致しているが, +これは間違いではない. +% + +%<*en> +For example, let us consider the case an Open comes after a Letter. +Since an Open represents Japanese open parenthesis, +it is preferred to be permitted to insert line break after the Letter. +Therefore, the collected character string is output in this case. +% +%<*ja> +例えば,Letterの直後にOpenが来た場合を考える. +文字種Openは和文開き括弧類を想定しているので,Letterの直後では行分割が可能であることが望ましい. +そのため,この場合では,すでに収集されている文字列を出力することで行分割を許容するようにした. +% + +%<*en> +The following table summarizes $5\times 5=25$ cases: +% +%<*ja> +同じように,$5\times 5=25$通り全てについて書くと,次のようになる: +% +\begin{center} +\small +\begin{tabular}{llccccc} +\toprule +%<*en> +&&\multicolumn{4}{c}{Next}\\\cmidrule(lr){3-7} +&&\hbox to 4em{\hss Letter\hss}&\hbox to 4em{\hss Other\hss} +&\hbox to 4em{\hss Kanji\hss}&\hbox to 4em{\hss Open\hss}&Close\\\midrule +&Letter&collects&\multicolumn{3}{c}{\hrulefill \ outputs\ \hrulefill}&collects\\ +&Other&outputs&collects&\multicolumn{2}{c}{\hrulefill \ outputs\ \hrulefill}&collects\\ +Prev&Kanji&\multicolumn{4}{c}{\hrulefill \ outputs\ \hrulefill}&collects\\ +&Open&\multicolumn{5}{c}{\hrulefill \ collects\ \hrulefill}\\ +&Close&\multicolumn{4}{c}{\hrulefill \ outputs\ \hrulefill}&collects\\ +% +%<*ja> +&&\multicolumn{4}{c}{後ろ側の文字}\\\cmidrule(lr){3-7} +&&\hbox to 4em{\hss Letter\hss}&\hbox to 4em{\hss Other\hss} +&\hbox to 4em{\hss Kanji\hss}&\hbox to 4em{\hss Open\hss}&Close\\\midrule +直&Letter&収集&\multicolumn{3}{c}{\hrulefill \ 出力\ \hrulefill}&収集\\ +前&Other&出力&収集&\multicolumn{2}{c}{\hrulefill \ 出力\ \hrulefill}&収集\\ +文&Kanji&\multicolumn{4}{c}{\hrulefill \ 出力\ \hrulefill}&収集\\ +字&Open&\multicolumn{5}{c}{\hrulefill \ 収集\ \hrulefill}\\ +種&Close&\multicolumn{4}{c}{\hrulefill \ 出力\ \hrulefill}&収集\\ +% +\bottomrule +\end{tabular} +\end{center} +%In the above table, +%上の表において, +\begin{itemize} +%\item ``outputs'' means to output the collected character string (i.e., line breaking is permitted there). +%\item 「出力」は,それまでに集めた文字列を出力(≒ここで行分割可能)を意味する. + +%\item ``collects'' means to append the next character to the collected character string (i.e., line breaking is prohibited there). +%\item 「収集」は,後側の文字を,現在収集された文字列に追加(行分割不可)を意味する. +\end{itemize} + +%\paragraph{Classification of characters} +%\paragraph{和文文字扱いとなる文字} + +%<*en> +Characters are classified according to \Param{jacharrange} parameter (see Section \ref{ssec-setrange}): +% +%<*ja> +\Pkg{listings} パッケージにおいて和文文字と扱われる +(前に述べたKanji, Open,あるいは「閉じ括弧類」分類)か否かは, +通常の\textbf{JAchar}/\textbf{Alchar}の範囲の設定(\Param{jacharrange} パラメータ,\ref{ssec-setrange}節を参照)に従って行われる: +% +\begin{itemize} +%\item \textbf{ALchars} above U+0080 are Letter. +%\item (U+0080以降の)\textbf{ALchar}は,すべてLetter扱いである. + +%\item \textbf{JAchars} are classified in the order as follows: +%\item (U+0080以降の)\textbf{JAchar}については,以下の順序に従って文字種を決める: +\begin{enumerate} +%\item Characters whose \Param{prebreakpenalty} is greater than or equal to 0 are Open. +%\item \Param{prebreakpenalty} が0以上の文字はOpen扱いである. + +%\item Characters whose \Param{postbreakpenalty} is greater than or equal to 0 are Close. +%\item \Param{postbreakpenalty} が0以上の文字はClose扱いである. + +%\item Characters that don't satisfy the above two conditions are Kanji. +%\item 上の2条件のどちらにも当てはまらなかった文字は,Kanji扱いである. +\end{enumerate} +\end{itemize} + +%<*en> +The width of halfwidth kana (U+FF61--U+FF9F) is same as the width of \textbf{ALchar}; +the width of the other \textbf{JAchars} is double the width of \textbf{ALchar}. +% +%<*ja> +なお,半角カナ(U+FF61--U+FF9F)以外の\textbf{JAchar}は欧文文字2文字分の幅をとるものとみなされる. +半角カナは欧文文字1文字分の幅となる. +% + +%<*en> +The classification process is executed every time a character appears in +listing environments. +% +%<*ja> +これらの文字種決定は,実際に \texttt{lstlisting} 環境などの内部で文字が出てくるたびに行われる. +% + +%<*ja> +\section{和文の行長補正方法} +\label{sec-adjspec} +\texttt{luatexja-adjust.sty} で提供される優先順位付きの行長調整の詳細を述 +べる.大まかに述べると,次のようになる. +\begin{itemize} +\item 通常の\TeX の行分割方法に従って,段落を行分割する.この段階では,行 + 長に半端が出た場合,その半端分は\Param{xkanjiskip}, + \Param{kanjiskip},JFMグルーの全てで(優先順位なく)負担される. +\item その後,\texttt{post\_linebreak\_filter} callbackを使い,\textbf{段 + 落中の各行ごとに},行末文字の位置を調整したり,優先度付きの行長調整 + を実現するためにグルーの伸縮度を調整する. +\texttt{luatexja-adjust.sty} の作用は,このcallbackを追加するだけであり, + この章の残りではcallbackでの処理について解説する. +\end{itemize} + +\paragraph{準備:合計伸縮量の計算} +グルーの伸縮度(\texttt{plus} や \texttt{minus} で指定されている値)には, +有限値の他に,\texttt{fi},\texttt{fil},\texttt{fill},\texttt{filll}と +いう4つの無限大レベル(後ろの方ほど大きい)があり,行の調整に +\texttt{fi} などの\textbf{無限大レベルの伸縮度が用いられている場合は,そ +の行に対しての処理を中止}する. + +よって,以降,問題にしている行の行長調整は伸縮度が有限長のグルーを用いて +行われているとして良い.まず,段落中の行中のグルーを +\begin{itemize} +\item 下のどれにも該当しないグルー +\item JFMグルー(優先度別にまとめられる) +\item 和欧文間空白(\Param{xkanjiskip}) +\item 和文間空白(\Param{kanjiskip}) +\end{itemize} +の$1+1+5+1=8$つに類別し,それぞれの種別ごとに許容されている伸縮度の合計を計算する. +また,行長と自然長との差の絶対値を計算し,それを\textit{total}とおく. + +\subsection{行末文字の位置調整} +まず,行末が文字クラス$n$の\textbf{Jachar}であった場合, +それを動かすことによって,\textbf{JAglue} が負担する調整量を少なくしようとする. +この行末文字の左右の移動可能量は,JFM中にある文字クラス$n$の定義の +\texttt{end\_stretch},~\texttt{end\_shrink}フィールドに全角単位の値として記述されている. + +例えば,行末文字が句点「。」であり,そこで用いられているJFM中に +\begin{verbatim} + [2] = { + chars = { '。', ... }, width = 0.5, ..., + end_stretch = 0.5, end_shrink = 0.5, + }, +\end{verbatim} +という指定があった場合,この行末の句点は +\begin{itemize} +\item 通常の\TeX の行分割処理で「半角以上の詰め」が行われていた場合, +この分の行中の\textbf{JAglue}の負担を軽減するため, +行末の句点を半角だけ右に移動する(ぶら下げ組を行う). +\item 通常の\TeX の行分割処理で「半角以上の空き」が行われていた場合, +逆に行末句点を半角左に移動させる(見た目的に全角取りとなる). +\item 以上のどちらでもない場合,行末句点の位置調整は行わない. +\end{itemize} +となる. + +行末文字を移動した場合,その分だけ\textit{total}の値を引いておく. + +\subsection{グルーの調整} +\textit{total}の分だけが,行中のグルーの伸縮度に応じて負担されることになる. +…… + +% + +%<*en> +\section{Advanced line-adjustment for Japanese characters} +\dots +% + + + + \begin{thebibliography}{99} \addcontentsline{toc}{section}{\refname} \bibitem{texbytopic} Victor Eijkhout, \emph{\TeX\ by Topic, A \TeX nician's Reference}, Addison-Wesley, 1992. +\bibitem{listings} C.\ Heinz, B.\ Moses. The \textsf{Listings} Package. +\bibitem{jlisting} Thor Watanabe. Listings\ -\ MyTeXpert. \newblock +\url{http://mytexpert.sourceforge.jp/index.php?Listings} +\bibitem{min10} 乙部厳己,min10フォントについて. +\url{http://argent.shinshu-u.ac.jp/~otobe/tex/files/min10.pdf} +\bibitem{jlreq} W3C Japanese Layout Task Force~(ed), Requirements for Japanese Text Layout (W3C Working Group Note), 2011, 2012. \newblock +\url{http://www.w3.org/TR/jlreq/}% +% \\日本語訳の書籍版:W3C日本語組版タスクフォース(編),『W3C技術ノート 日本語組版処理の要件』,東京電機大学出版局,2012. +\bibitem{x4051} 日本工業規格(Japanese Industrial Standard) JIS~X~4051, +日本語文書の組版方法(Formatting rules for Japanese documents), 1993, 1995, 2004. \end{thebibliography} \newpage \appendix -%<*ja> -\section{\LuaTeX-jaにおけるJIS~X~0213非漢字のcatcode} +%\section{The category code of non-kanji characters defined in JIS~X~0213} +%\section{\LuaTeX-jaにおけるJIS~X~0213非漢字のcatcode} + +%<*en> +In these tables, the default catcode (\LuaTeX-ja) and kcatcode ((u)\pTeX) of non-kanji +characters defined in JIS~X~0213 from row 1 to row 13 is summarized. +Each character is printed as follows: +% +%<*ja> ここでは,JIS~X~0213の非漢字部分(第1区〜第13区)のうち, どの文字が(u)\pTeX や\LuaTeX-jaで制御綴内に使用可能かを表にしてまとめる. 各文字は +% \begin{center} \tt\fboxsep=1pt\fbox{\hbox to \zw{\gt あ\hss}}\,\scriptsize LUP \end{center} +%<*ja> のように表示しており,各文字は次の意味を持っている. -この表の生成は,JIS X 0208の範囲内の文字については\verb+\jis+命令を使って行なっている. +この表の生成は,JIS~X~0208の範囲内の文字については\verb+\jis+命令を使って行なっている. +% +%<*en> +The tables are generated by using \verb+\jis+ command for characters included in +JIS~X~0208. +Each character in the tables means: +% \begin{itemize} +%<*en> +\item The background of a character regarded as \textbf{ALchar} in \LuaTeX-ja + is colored light blue. +% +%<*ja> \item 背景が薄く青く塗られている文字は, \LuaTeX-ja の標準で\textbf{ALchar}として認識されている文字である. +% + +%<*en> +\item The first letter {\tt L} means that the character is available for + the name of a control sequence in \XeTeX{} and \LuaTeX-ja (its catcode is 11). +% +%<*ja> \item 1文字目の {\tt L} は,\XeTeX や\LuaTeX-jaにおいてこの文字が制御綴内に 使用可能(catcodeが11)であることを表している. +% + +%<*en> +\item The second letter {\tt U} means that the character is available for + the name of a control sequence in \upTeX{} (its kcatcode is 16 or 17). + \upTeX{} regards these characters as Japanese character. +% +%<*ja> \item 2文字目の{\tt U} は,\upTeX においてこの文字が制御綴内に使用可能(kcatcodeは16,~17)であることを 表している.この範囲内では,\upTeX は標準で全文字を和文文字として扱うようである. +% + +%<*en> +\item The third letter {\tt P} means that the character is available for + the name of a control sequence in \pTeX{} (its kcatcode is 16 or 17). +% +%<*ja> \item 3文字目の {\tt P} は,\pTeX においてこの文字が制御綴内に使用可能(kcatcodeは16,~17)であることを 表している. +% + +%<*en> +\item If the third letter is {\tt -} (or the character is printed in red), + the character is not included in JIS~X~0208. + Therefore, you can consider the character is not available in \pTeX. +% +%<*ja> \item 3文字目が{\tt -}となっているもの(本体の文字も赤身がかっている)は, -JIS~X~0208にないため使用不能と考えて良いものである. +JIS~X~0208にないため\pTeX では使用不能と考えて良いものである. +% + +%<*en> +\item The kana for bidakuon in row 4 and 5 are omitted. +% +%<*ja> \item 第4区と第5区にある,鼻濁音の仮名については省略した. +% \end{itemize} @@ -6317,7 +6815,9 @@ JIS~X~0208にないため使用不能と考えて良いものである. } \def\test#1{{% -\subsection*{第#1区}\tt\small\fboxsep=1pt\centering\tabcolsep=0.25\zw +%\subsection*{Row #1} +%\subsection*{第#1区} +\tt\small\fboxsep=1pt\centering\tabcolsep=0.25\zw \begin{tabular}{ccccccccccccccccc}\toprule&"0&"1&"2&"3&"4&"5&"6&"7&"8&"9&"A&"B&"C&"D&"E&"F\\ \out{#1}{2}\out{#1}{3}\out{#1}{4}\out{#1}{5}\out{#1}{6}\out{#1}{7}\bottomrule \end{tabular}\par}\medskip} @@ -6325,8 +6825,6 @@ JIS~X~0208にないため使用不能と考えて良いものである. \test{1}\test{2}\test{3}\test{4}\test{5}\test{6}\test{7}\test{8} \test{9}\test{10}\test{11}\test{12}\test{13} -% - \section{Package versions used in this document} This document was typeset using the following packages: @@ -6354,7 +6852,7 @@ This document was typeset using the following packages: %% %% config file for showexpl.sty %% -%% Copyright The LuaTeX-ja project team, 2005 +%% Copyright The LuaTeX-ja project team, 2012 %% \ProvidesFile{showexpl.cfg} [2012/05/20 v0.01 Definitions for the showexpl package (luatexja)]