1 % \iffalse meta-comment
3 % -------------------------------------
4 % Original: jltxdoc.dtx
6 % Copyright 1995,1996,1997 ASCII Corporation.
7 % Copyright (c) 2010 ASCII MEDIA WORKS
8 % Copyright (c) 2016 Japanese TeX Development Community
9 % Copyright (c) 2016-2017 Japanese TeX Development Community
11 % This file is part of the pLaTeX2e system (community edition).
12 % -------------------------------------
16 % \setcounter{StandardModuleDepth}{1}
20 % \changes{v1.0a}{1997/01/23}{\LaTeX \texttt{!<1996/12/01!>}への対応に
22 % \changes{v1.0b}{1997/07/29}{\cs{}と\texttt{"}の\cs{xspcode}を変更}
23 % \changes{v1.0b-ltj}{2011/09/27}{Lua\LaTeX-ja 用に修正}
24 % \changes{v1.0b-ltj-2}{2014/07/03}{orを意味する縦棒の出力が異常だったので修正}
25 % \changes{v1.0c}{2016/07/25}{docパッケージが上書きする\cs{verb}を再々定義}
26 % \changes{v1.0d}{2017/09/24}{\cs{vadjust\{\}}を追加}
27 % \changes{v1.0d-ltj-3}{2018/01/01}{\cs{Cjascale}を追加}
32 %<class>\NeedsTeXFormat{LaTeX2e}
33 %<class>\ProvidesClass{ltjltxdoc}[2018/01/01 v1.0d-ltj-3 Standard LuaLaTeX-ja file]
35 \documentclass{ltjltxdoc}
36 \GetFileInfo{ltjltxdoc.cls}
38 \suppressfontnotfounderror=1
39 \global\font\testfont=file:KozMinPr6N-Regular.otf
40 \global\font\testfonta=file:HaranoAjiMincho-Regular.otf
42 \ifx\testfonta\nullfont\ifx\testfont\nullfont
43 \usepackage[ipaex,nfssonly]{luatexja-preset}
45 \usepackage[kozuka-pr6n,nfssonly]{luatexja-preset}
47 \usepackage[haranoaji,nfssonly]{luatexja-preset}
49 \let\testfont\undefined\let\testfonta\undefined
50 \usepackage{unicode-math}
51 \setmathfont{Latin Modern Math}
52 \title{Lua\LaTeX-jaドキュメント記述用クラス}
53 \author{Lua\TeX-jaプロジェクト}
57 \DocInput{ltjltxdoc.dtx}
62 % \file{ltjltxdoc}クラスは、\file{ltxdoc}をテンプレートにして、日本語用の
66 \DeclareOption*{\PassOptionsToClass{\CurrentOption}{ltxdoc}}
70 % \file{ltxdoc}の読み込み後に\file{luatexja}を読み込みます。
72 % \changes{v1.60d-ltj-3}{2018/01/01}{\cs{Cjascale}を追加しました。
73 % これは、コミュニティ版p\kern-.05em\LaTeX で導入された、
74 % 和文スケール($1\,\cs{zw} \div \hbox{要求サイズ}$)を表す実数値マクロです。}
77 \RequirePackage{luatexja}
78 \def\Cjascale{0.962216}
81 % \begin{macro}{\normalsize}
82 % \begin{macro}{\small}
83 % \begin{macro}{\parindent}
84 % \changes{v1.0a}{1997/01/23}{\cs{normalsize}, \cs{small}などの再定義}
85 % \file{ltxdoc}からロードされる\file{article}クラスでの行間などの設定値で、
86 % 日本語の文章を組版すると、行間が狭いように思われるので、多少広くするように
87 % 再設定します。また、段落先頭での字下げ量を全角一文字分とします。
89 \renewcommand{\normalsize}{%
90 \@setfontsize\normalsize\@xpt{15}%
91 \abovedisplayskip 10\p@ \@plus2\p@ \@minus5\p@
92 \abovedisplayshortskip \z@ \@plus3\p@
93 \belowdisplayshortskip 6\p@ \@plus3\p@ \@minus3\p@
94 \belowdisplayskip \abovedisplayskip
96 \renewcommand{\small}{%
97 \@setfontsize\small\@ixpt{11}%
98 \abovedisplayskip 8.5\p@ \@plus3\p@ \@minus4\p@
99 \abovedisplayshortskip \z@ \@plus2\p@
100 \belowdisplayshortskip 4\p@ \@plus2\p@ \@minus2\p@
101 \def\@listi{\leftmargin\leftmargini
102 \topsep 4\p@ \@plus2\p@ \@minus2\p@
103 \parsep 2\p@ \@plus\p@ \@minus\p@
105 \belowdisplayskip \abovedisplayskip}
107 \setlength\parindent{1\zw}
113 % \begin{macro}{\file}
114 % |\file|マクロは、ファイル名を示すのに用います。
116 \providecommand*{\file}[1]{\texttt{#1}}
120 % \begin{macro}{\pstyle}
121 % |\pstyle|マクロは、ページスタイル名を示すのに用います。
123 \providecommand*{\pstyle}[1]{\textsl{#1}}
127 % \begin{macro}{\Lcount}
128 % |\Lcount|マクロは、カウンタ名を示すのに用います。
130 \providecommand*{\Lcount}[1]{\textsl{\small#1}}
134 % \begin{macro}{\Lopt}
135 % |\Lopt|マクロは、クラスオプションやパッケージオプションを示すのに用います。
137 \providecommand*{\Lopt}[1]{\textsf{#1}}
141 % \begin{macro}{\dst}
142 % |\dst|マクロは、``\dst''を出力する。
144 \providecommand\dst{{\normalfont\scshape docstrip}}
148 % \begin{macro}{\NFSS}
149 % |\NFSS|マクロは、``\NFSS''を出力します。
151 \providecommand\NFSS{\textsf{NFSS}}
155 % \begin{macro}{\c@clineno}
156 % \begin{macro}{\mlineplus}
157 % |\mlineplus|マクロは、その時点でのマクロコードの行番号に、引数に指定された
158 % 行数だけを加えた数値を出力します。たとえば|\mlineplus{3}|とすれば、
159 % 直前のマクロコードの行番号(\arabic{CodelineNo})に3を加えた数、
160 % ``\mlineplus{3}''が出力されます。
162 \newcounter{@clineno}
163 \def\mlineplus#1{\setcounter{@clineno}{\arabic{CodelineNo}}%
164 \addtocounter{@clineno}{#1}\arabic{@clineno}}
169 % \begin{environment}{tsample}
170 % |tsample|環境は、環境内に指定された内容を罫線で囲って出力をします。
171 % 第一引数は、出力するボックスの高さです。
172 % このマクロ内では縦組になることに注意してください。
175 \hbox to\linewidth\bgroup\vrule width.1pt\hss
176 \vbox\bgroup\hrule height.1pt
177 \vskip.5\baselineskip
178 \vbox to\linewidth\bgroup\tate\hsize=#1\relax\vss}
181 \vskip.5\baselineskip
182 \hrule height.1pt\egroup
183 \hss\vrule width.1pt\egroup}
187 % \begin{macro}{\verb}
188 % p\LaTeX{}では、|\verb|コマンドを修正して直前に|\xkanjiskip|が入るように
189 % しています。しかし、\file{ltxdoc.cls}が読み込む\file{doc.sty}が上書き
190 % してしまいますので、これを再々定義します。\file{doc.sty}での定義は
192 % \def\verb{\relax\ifmmode\hbox\else\leavevmode\null\fi
193 % \bgroup \let\do\do@noligs \verbatim@nolig@list
194 % \ttfamily \verb@eol@error \let\do\@makeother \dospecials
195 % \@ifstar{\@sverb}{\@vobeyspaces \frenchspacing \@sverb}}
197 % となっていますので、\file{plcore.dtx}と同様に|\null|を外して|\vadjust{}|を
199 % \changes{v1.0c}{2016/07/25}{docパッケージが上書きする\cs{verb}を再々定義}
200 % \changes{v1.0d}{2017/09/24}{\cs{vadjust\{\}}を追加}
202 \def\verb{\relax\ifmmode\hbox\else\leavevmode\vadjust{}\fi
203 \bgroup \let\do\do@noligs \verbatim@nolig@list
204 \ttfamily \verb@eol@error \let\do\@makeother \dospecials
205 \@ifstar{\@sverb}{\@vobeyspaces \frenchspacing \@sverb}}
209 % \begin{macro}{alxspmode}
210 % コマンド名の|\|と16進数を示すための|"|の前にもスペースが入るよう、
211 % これらの|alxspmode|の値を変更します。
212 % \changes{v1.0b}{1997/07/29}{\cs{}と\texttt{"}の\cs{xspcode}を変更}
213 % \changes{v1.0b-ltj}{2011/09/27}{\cs{xspcode}→\cs{ltjsetparameter{alxspmode={...}}}}
215 \ltjsetparameter{alxspmode={"5C,3}} %% \
216 \ltjsetparameter{alxspmode={"22,3}} %% "
221 % \begin{macro}{mod@math@codes}
222 % docパッケージでは,ドライバ指定の表示の部分における\texttt{\char`\|}の
223 % \cs{mathcode}は\texttt{"226A}になっており,これにより\texttt{\char`\|}が小文字のjで表示されて
224 % しまう状況になっています.改善するため,\texttt{"207C}に変更します.
226 \def\mod@math@codes{\mathcode`\|="207C \mathcode`\&="2026
227 \mathcode`\-="702D \mathcode`\+="702B
228 \mathcode`\:="703A \mathcode`\=="703D }