X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=src%2Fltjsclasses.dtx;h=256a917828e47c8e0af3e1af459b1109f00b0eee;hb=35f327cea38d7ac9d6933227c72310f3a02ef7bf;hp=f925644e854d39febd22fe4e3796a3bc6ef37a69;hpb=7bcf7b03364c032a71f9ea1d185fe185ecc2c718;p=luatex-ja%2Fluatexja.git diff --git a/src/ltjsclasses.dtx b/src/ltjsclasses.dtx index f925644..256a917 100644 --- a/src/ltjsclasses.dtx +++ b/src/ltjsclasses.dtx @@ -3,29 +3,19 @@ % ----------------------------------------- % Original: jsclasses.dtx % -% pLaTeX2ε新ドキュメントクラス +% pLaTeX2ε新ドキュメントクラス(日本語 TeX 開発コミュニティ版) +% 原作者:奥村晴彦 % -% これは LaTeX3 Project の classes.dtx と株式会社アスキーの jclasses.dtx -% に基づいて奥村 が改変したものです。 -% 奥村の改変部分については何の権利も主張しません。 -% オリジナルの著作権の許す範囲で自由にご利用ください。 -% -% [2002-12-19] いろいろなものに収録していただく際にライセンスを明確にする -% 必要が生じてきました。アスキーのものが最近はmodified BSDライセンスになっ -% ていますので,私のものもそれに準じてmodified BSDとすることにします。 -% -% [2016-07-11] abenoriさんによる\texttt{nomag}オプションをマージしました。 -% なお,ソースコードの管理はGitHubで行うことにしました。 -% -% Copyright 1993 1994 1995 1996 1997 1998 1999 +% Copyright 1993-2016 % The LaTeX3 Project and any individual authors listed elsewhere -% in this file. +% in this file. % % Copyright 1995-1999 ASCII Corporation. +% Copyright 1999-2016 Haruhiko Okumura +% Copyright 2016-2018 Japanese TeX Development Community % ----------------------------------------- % % \fi -% \CheckSum{5229} %% \CharacterTable %% {Upper-case \A\B\C\D\E\F\G\H\I\J\K\L\M\N\O\P\Q\R\S\T\U\V\W\X\Y\Z %% Lower-case \a\b\c\d\e\f\g\h\i\j\k\l\m\n\o\p\q\r\s\t\u\v\w\x\y\z @@ -45,34 +35,44 @@ % \iffalse % % \begin{macrocode} -%\NeedsTeXFormat{LaTeX2e} +\NeedsTeXFormat{LaTeX2e} %
\ProvidesClass{ltjsarticle} %\ProvidesClass{ltjsbook} +%\ProvidesClass{ltjsreport} %\ProvidesClass{ltjspf} %\ProvidesClass{ltjskiyou} %<*driver> \ProvidesFile{ltjsclasses.dtx} % - [2016/07/14 ltjsclasses ] + [2018/10/08 ltjsclasses ] %<*driver> \IfFileExists{luatex85.sty}{\RequirePackage{luatex85}}{} -\documentclass{ltjsarticle} -\usepackage{doc} -\usepackage{fontspec} -\usepackage[ipaex,nfssonly]{luatexja-preset} +\documentclass[disablejfam]{ltjsarticle} +\usepackage{hypdoc} +\hypersetup{unicode=true} +\begingroup + \suppressfontnotfounderror=1 + \global\font\testfont=file:KozMinPr6N-Regular.otf +\endgroup +\ifx\testfont\nullfont + \usepackage[ipaex,nfssonly]{luatexja-preset} +\else + \usepackage[kozuka-pr6n,nfssonly]{luatexja-preset} +\fi +\ltjsetparameter{alxspmode={`\*,allow}} +\ltjsetparameter{alxspmode={`\\,allow}} %%%%\usepackage{unicode-math} %%%%\setmathfont{Latin Modern Math} -\usepackage[unicode]{hyperref} \addtolength{\textwidth}{-1in} \addtolength{\evensidemargin}{1in} \addtolength{\oddsidemargin}{1in} \addtolength{\marginparwidth}{1in} \setlength\marginparpush{0pt} % \OnlyDescription -\DisableCrossrefs +\CodelineNumbered +\EnableCrossrefs \setcounter{StandardModuleDepth}{1} \GetFileInfo{ltjsclasses.dtx} -\CodelineNumbered \begin{document} \DocInput{ltjsclasses.dtx} \end{document} @@ -91,49 +91,61 @@ % % \section{はじめに} % -% これは奥村晴彦先生による |jsclasses.dtx| をLua\LaTeX-ja用に改変したものです。 +% これは,元々奥村晴彦先生により作成され,現在は日本語\TeX 開発コミュニティにより +% 管理されている\texttt{jsclasses.dtx}をLua\LaTeX-ja用に改変したものです。 % 次のドキュメントクラス(スタイルファイル)を生成します。 +% +% [2017-02-13] forum:2121の議論を機に,ltjsreportクラスを新設しました。 +% 従来のltjsbookの |report| オプションと比べると,|abstract| 環境の使い方 +% および挙動がアスキーのjreportに近づきました。 +% % \begin{quote} % \begin{tabular}{lll} % $\langle$\textsf{article}$\rangle$ & \texttt{ltjsarticle.cls} & 論文・レポート用 \\ % $\langle$\textsf{book}$\rangle$ & \texttt{ltjsbook.cls} & 書籍用 \\ +% $\langle$\textsf{report}$\rangle$ & \texttt{ltjsreport.cls} & レポート用 \\ % $\langle$\textsf{jspf}$\rangle$ & \texttt{ltjspf.cls} & 某学会誌用 \\ -% $\langle$\textsf{kiyou}$\rangle$ & \texttt{ltjskiyou.cls} & 某紀要用 +% $\langle$\textsf{kiyou}$\rangle$ & \texttt{ltjskiyou.cls} & 某紀要用 % \end{tabular} % \end{quote} % -% |ltjclasses| と違うのは以下の点です。 -% % \subsection{\texttt{jsclasses.dtx}からの主な変更点} -% 全ての変更点を知りたい場合は,|jsclasses.dtx| と |ltjsclasses.dtx| で |diff| を +% 全ての変更点を知りたい場合は,\texttt{jsclasses.dtx}と\texttt{ltjsclasses.dtx}でdiffを % とって下さい。zw, zh は全て |\zw|, |\zh| に置き換えられています。 % \begin{itemize} -% \item フォントメトリック関係のオプション |winjis| は単に無視されます。 -% \item 標準では |jfm-ujis.lua|(Lua\TeX-ja標準のメトリック,OTFパッケージのものがベース)を使用します。 -% \item |uplatex| オプションを削除してあります。 -% \item |disablejfam| オプションが無効になっています。もし +% \item フォントメトリック関係のオプション\texttt{winjis}は単に無視されます。 +% \item 標準では\texttt{jfm-ujis.lua}(Lua\TeX-ja標準のメトリック,OTFパッケージのものがベース)を使用します。 +% \item \texttt{uplatex}オプション,\texttt{autodetect-engine}オプションを +% 削除してあります(前者ではエラーを出すようにしています)。 +% \item \texttt{disablejfam}オプションはクラス側では何もしません(ただLua\TeX-ja本体に +% 渡されるだけです).もし % \begin{quotation} % |! LaTeX Error: Too many math alphabets used in version ****.| % \end{quotation} -% のエラーが起こった場合は,|lualatex-math| パッケージを読み込んでみて下さい。 -% \item |papersize| オプションの指定に関わらずPDFのページサイズは適切に +% のエラーが起こった場合は,\texttt{lualatex-math}パッケージを読み込んでみて下さい。 +% \item \texttt{papersize}オプションの指定に関わらずPDFのページサイズは適切に % 設定されます。 % \item Lua\TeX-ja同梱のメトリックを用いる限りは,段落の頭にグルーは挿入されません。 -% そのため,オリジナルの |jsclasses.dtx| 内にあったhack (|\everyparhook|)は不要になったので, +% そのため,オリジナルの\texttt{jsclasses}内にあったhack (|\everyparhook|)は不要になったので, % 削除しました。 % \item 「\texttt{amsmath}との衝突の回避」のコードは,上流で既に対処されているうえ, -% これがあると |grfext.sty| を読み込んだ際にエラーを引き起こすので削除しました。 -% \item 本家 |jsclasses.dtx| では |\mag| を用いて「10pt時の組版結果を本文フォントサイズに合わせ拡大縮小」 -% という方針でしたが,本 |ltjsclasses.dtx| ではそのような方法を取っていません。 +% これがあると\texttt{grfext.sty}を読み込んだ際にエラーを引き起こすので削除しました。 +% \item 本家\texttt{jsclasses}では |\mag| を用いて「10\,pt時の組版結果を本文フォントサイズに合わせ拡大縮小」 +% という方針でしたが,本\texttt{ltjsclasses}ではそのような方法を取っていません。 % \begin{itemize} -% \item |nomag| オプション指定時には,単にレイアウトに用いる各種長さの値をスケールさせるだけです。 -% そのため,例えば本文の文字サイズが17ptのときにはcmr10でなくcmr17を用いることになり,組版結果の印象が +% \item \texttt{nomag}オプション指定時には,単にレイアウトに用いる各種長さの値をスケールさせるだけです。 +% そのため,例えば本文の文字サイズが17\,ptのときにはcmr10でなくcmr17を用いることになり,組版結果の印象が % 異なる恐れがあります。 -% \item |nomag*| オプション指定時には,上記に加えてオプティカルサイズを調整する(本文ではcmr17の代わりに +% \item \texttt{nomag*}オプション指定時には,上記に加えてオプティカルサイズを調整する(本文ではcmr17の代わりに % cmr10を拡大縮小する,など)ため,\LaTeX のフォント選択システムNFSSへパッチを当てます。 -% こうすることで前項に書いた不具合はなくなりますが,かえって別の不具合が起きる可能性はあります。 +% こうすることで前項に書いた不具合はなくなりますが,かえって別の不具合が起きる可能性 +% はあります\footnote{% +% \texttt{nomag*}は\texttt{jsclasses}でも利用可能ですが,\texttt{ltjsclasses}では\texttt{jsclasses}とは +% 別の実装をしています。 +% }。 % \end{itemize} -% 標準では |nomag*| オプションが有効になっています。 +% 標準では\texttt{nomag*}オプションが有効になっています。\texttt{jsclasses}で用意され,かつ既定になっている +% \texttt{usemag}オプションを指定すると警告を出します。 % \end{itemize} % % [2014-02-07 LTJ] jsclasses 2014-02-07 ベースにしました。 @@ -146,19 +158,41 @@ % Lua\TeX-ja カーネル内に移しました。 % % [2016-03-21 LTJ] Lua\TeX~beta-0.87.0 ではPDF出力時に|\mag|が使用できなくなったので, -% ZRさんの|bxjscls|を参考に使わないように書き換えました。 +% ZRさんの\texttt{bxjscls}を参考に使わないように書き換えました。 +% +% [2016-03-31 LTJ] \texttt{xreal}オプションを標準で有効にしました。 +% +% [2016-07-12 LTJ] \texttt{jsclasses}開発版に合わせ,\texttt{real},~\texttt{xreal}オプションの名称を変更するなどの変更を行いました。 +% +% [2016-07-18 LTJ] \texttt{usemag}オプションが指定されると警告を出すようにしました。 % -% [2016-03-31 LTJ] |xreal|オプションを標準で有効にしました. +% [2016-07-21 LTJ] \LaTeX 等のロゴの再定義で,\texttt{jslogo}パッケージがあればそちらを読み込むことにしました。 % -% [2016-07-12 LTJ] jsclasses 開発版に合わせ、|real|, |xreal| オプションの名称を変更するなどの変更を行いました。 +% [2016-10-13 LTJ] \texttt{slide}オプションの使用時にエラーが出るのを修正. % % \StopEventually{} % % 以下では実際のコードに即して説明します。 +% +% \begin{macro}{\jsc@clsname} +% +% 文書クラスの名前です。エラーメッセージ表示などで使われます。 +% +% \begin{macrocode} +%
\def\jsc@clsname{ltjsarticle} +%\def\jsc@clsname{ltjsbook} +%\def\jsc@clsname{ltjsreport} +%\def\jsc@clsname{ltjspf} +%\def\jsc@clsname{ltjskiyou} +% \end{macrocode} +% \end{macro} +% % \section{Lua\TeX-jaの読み込み} % -% まず,|luatexja| を読み込みます。 +% 和文スケール値を設定した後に,Lua\TeX-jaを読み込みます。 % \begin{macrocode} +%\def\Cjascale{0.924715} +%\def\Cjascale{0.903375} \RequirePackage{luatexja} % \end{macrocode} % @@ -191,11 +225,20 @@ % % \begin{macro}{\if@openright} % -% |\chapter|,|\part| を奇数ページ起こしにするかどうかです。 -% 書籍では真が標準です。 +% |\chapter|,|\part| を右ページ起こしにするかどうかです。 +% 横組の書籍では真が標準で,要するに片起こし,奇数ページ起こしになります。 +% +% \begin{macrocode} +%\newif\if@openright +% \end{macrocode} +% \end{macro} +% +% \begin{macro}{\if@openleft} +% +% [2017-02-24] |\chapter|,|\part| を左ページ起こしにするかどうかです。 % % \begin{macrocode} -%\newif\if@openright +%\newif\if@openleft % \end{macrocode} % \end{macro} % @@ -236,7 +279,7 @@ % \pLaTeXe の \texttt{b5paper} % は $257\,\mathrm{mm} \times 182\,\mathrm{mm}$ になっています。 % ここでは\pLaTeXe にならってJISに従いました。 -% +% % デフォルトは \texttt{a4paper} です。 % % \texttt{b5var}(B5変形,182mm×230mm), @@ -307,6 +350,9 @@ % % オプション \texttt{slide} を新設しました。 % +% [2016-10-08] \texttt{slide} オプションは article 以外では使い物にならなかったので, +% 簡単のため article のみで使えるオプションとしました。 +% % \begin{macrocode} \newif\if@slide \@slidefalse @@ -323,55 +369,69 @@ % % [2003-04-18] 12Qオプションを追加しました。 % +% [2016-07-08] |\mag| を使わずに各種寸法をスケールさせるためのオプション \texttt{nomag} を新設しました。 +% \texttt{usemag} オプションの指定で従来通りの動作となります。デフォルトは \texttt{usemag} です。 +% +% [2016-07-24] オプティカルサイズを調整するためにNFSSへパッチを当てるオプション \texttt{nomag*} を新設しました。 +% % \begin{macrocode} -\def\js@magscale{1} -\DeclareOption{slide}{\@slidetrue\def\js@magscale{3.583}\@landscapetrue\@titlepagetrue} -\DeclareOption{8pt} {\def\js@magscale{0.83}}% 1.2^(-1) -\DeclareOption{9pt} {\def\js@magscale{0.913}}% 1.2^(-0.5} -\DeclareOption{10pt}{\def\js@magscale{1}} -\DeclareOption{11pt}{\def\js@magscale{1.095}}% 1.2^0.5 -\DeclareOption{12pt}{\def\js@magscale{1.200}} -\DeclareOption{14pt}{\def\js@magscale{1.440}} -\DeclareOption{17pt}{\def\js@magscale{1.728}} -\DeclareOption{20pt}{\def\js@magscale{2}} -\DeclareOption{21pt}{\def\js@magscale{2.074}} -\DeclareOption{25pt}{\def\js@magscale{2.488}} -\DeclareOption{30pt}{\def\js@magscale{2.986}} -\DeclareOption{36pt}{\def\js@magscale{3.583}} -\DeclareOption{43pt}{\def\js@magscale{4.300}} -\DeclareOption{12Q} {\def\js@magscale{0.923}}% 1pt*12Q/13Q -\DeclareOption{14Q} {\def\js@magscale{1.077}}% 1pt*14Q/13Q -\DeclareOption{10ptj}{\def\js@magscale{1.085}}% 1pt*10bp/13Q -\DeclareOption{10.5ptj}{\def\js@magscale{1.139}} -\DeclareOption{11ptj}{\def\js@magscale{1.194}} -\DeclareOption{12ptj}{\def\js@magscale{1.302}} +\def\jsc@magscale{1} +%<*article> +\DeclareOption{slide}{\@slidetrue\def\jsc@magscale{3.583}\@landscapetrue\@titlepagetrue} +%
+\DeclareOption{8pt} {\def\jsc@magscale{0.833}}% 1.2^(-1) +\DeclareOption{9pt} {\def\jsc@magscale{0.913}}% 1.2^(-0.5} +\DeclareOption{10pt}{\def\jsc@magscale{1}} +\DeclareOption{11pt}{\def\jsc@magscale{1.095}}% 1.2^0.5 +\DeclareOption{12pt}{\def\jsc@magscale{1.200}} +\DeclareOption{14pt}{\def\jsc@magscale{1.440}} +\DeclareOption{17pt}{\def\jsc@magscale{1.728}} +\DeclareOption{20pt}{\def\jsc@magscale{2}} +\DeclareOption{21pt}{\def\jsc@magscale{2.074}} +\DeclareOption{25pt}{\def\jsc@magscale{2.488}} +\DeclareOption{30pt}{\def\jsc@magscale{2.986}} +\DeclareOption{36pt}{\def\jsc@magscale{3.583}} +\DeclareOption{43pt}{\def\jsc@magscale{4.300}} +\DeclareOption{12Q} {\def\jsc@magscale{0.923}}% 1pt*12Q/13Q +\DeclareOption{14Q} {\def\jsc@magscale{1.077}}% 1pt*14Q/13Q +\DeclareOption{10ptj}{\def\jsc@magscale{1.085}}% 1pt*10bp/13Q +\DeclareOption{10.5ptj}{\def\jsc@magscale{1.139}} +\DeclareOption{11ptj}{\def\jsc@magscale{1.194}} +\DeclareOption{12ptj}{\def\jsc@magscale{1.302}} % \end{macrocode} % % \paragraph{オプティカルサイズの補正} -% |nomag*| オプション指定時には,本文のフォントサイズが10pt以外の場合に +% \texttt{nomag*}オプション指定時には,本文のフォントサイズが10pt以外の場合に % オプティカルサイズの補正を行うためにNFSSにパッチを当てます。 -% 現在の |ltjsclasses| ではこのパッチ当ては標準では行いますが, -% 将来どうなるかわからないので |nomag| で無効化することができるようにしました。 +% 現在の\texttt{ltjsclasses}ではこのパッチ当ては標準では行いますが, +% 将来どうなるかわからないので\texttt{nomag}で無効化することができるようにしました。 +% +% \texttt{noxreal},~\texttt{real}は旧来の互換性として今は残してありますが,2017年7月に削除する予定です。 +% +% [2018-01-14] \texttt{noxreal},~\texttt{real} を削除しました.また,内部命令の名称を +% \texttt{jsclasses}に合わせました. % -% |noxreal|, |real| は旧来の互換性として今は残してありますが、将来は削除する予定です。 % \begin{macrocode} -\newif\if@ltjs@mag@xreal -\@ltjs@mag@xrealtrue -\DeclareOption{nomag*}{\@ltjs@mag@xrealtrue} -\DeclareOption{nomag}{\@ltjs@mag@xrealfalse} -\DeclareOption{noxreal}{\@ltjs@mag@xrealfalse} -\DeclareOption{real}{\@ltjs@mag@xrealfalse} +\newif\ifjsc@mag@xreal +\jsc@mag@xrealtrue +\DeclareOption{nomag*}{\jsc@mag@xrealtrue} +\DeclareOption{nomag}{\jsc@mag@xrealfalse} +\DeclareOption{usemag}{% + \ClassWarningNoLine{\jsc@clsname}{% + This \jsc@clsname\space cls does not support `usemag'\MessageBreak + option, since LuaTeX does not support \string\mag\MessageBreak in pdf output}% + \jsc@mag@xrealtrue} % \end{macrocode} % % % \paragraph{トンボオプション} % % トンボ(crop marks)を出力します。 -% 実際の処理は |lltjcore.sty| で行います。 +% 実際の処理は\texttt{lltjcore.sty}で行います。 % オプション \texttt{tombow} で日付付きのトンボ, % オプション \texttt{tombo} で日付なしのトンボを出力します。 % これらはアスキー版のままです。 -% カウンタ |\hour|,|\minute| は |luatexja-compat.sty| で宣言されています。 +% カウンタ |\hour|,|\minute| は\texttt{luatexja-compat.sty}で宣言されています。 % % \begin{macrocode} \hour\time \divide\hour by 60\relax @@ -434,12 +494,20 @@ % % \paragraph{右左起こし} % -% 書籍では章は通常は奇数ページ起こしになりますが, +% 書籍では章は通常は奇数ページ起こしになりますが,横組ではこれを +% \texttt{openright} と表すことにしてあります。 % \texttt{openany} で偶数ページからでも始まるようになります。 % +% [2017-02-24] \texttt{openright} は横組では奇数ページ起こし,縦組では +% 偶数ページ起こしを表します。ややこしいですが,これは\LaTeX の標準クラスが +% 西欧の横組事情しか考慮せずに,奇数ページ起こしと右起こしを一緒にしてしまっ +% たせいです。縦組での奇数ページ起こしと横組での偶数ページ起こしも表現したい +% ので,ltjsclassesでは新たに \texttt{openleft} も追加しました。 +% % \begin{macrocode} -%\DeclareOption{openright}{\@openrighttrue} -%\DeclareOption{openany}{\@openrightfalse} +%\DeclareOption{openright}{\@openrighttrue\@openleftfalse} +%\DeclareOption{openleft}{\@openlefttrue\@openrightfalse} +%\DeclareOption{openany}{\@openrightfalse\@openleftfalse} % \end{macrocode} % % \paragraph{eqnarray環境と数式の位置} @@ -523,21 +591,21 @@ % % \paragraph{数式フォントとして和文フォントを登録しないオプション} % -% p\TeX では数式中では16通りのフォントしか使えませんでしたが,Lua\TeX では +% \pTeX では数式中では16通りのフォントしか使えませんでしたが,Lua\TeX では % Omega拡張が取り込まれていて256通りのフォントが使えます。 % ただし,\LaTeXe カーネルでは未だに数式ファミリの数は16個に制限されているので, -% 実際に使用可能な数式ファミリの数を増やすためには |lualatex-math| パッケージを +% 実際に使用可能な数式ファミリの数を増やすためには\texttt{lualatex-math}パッケージを % 読み込む必要があることに注意が必要です。 % -% \begin{macrocode} -\DeclareOption{disablejfam}{% - \ClassWarningNoLine{\@currname}{The class option 'disablejfam' is obsolete}} -% \end{macrocode} +% [2018-10-08 LTJ] Lua\TeX-ja本体が\texttt{disablejfam}オプションをサポートしたので, +% クラスファイルからは削除します. % % \paragraph{ドラフト} % % \texttt{draft} でoverfull boxの起きた行末に5ptの罫線を引きます。 % +% [2016-07-13] |\ifdraft| を定義するのをやめました。 +% % \begin{macrocode} \DeclareOption{draft}{\setlength\overfullrule{5pt}} \DeclareOption{final}{\setlength\overfullrule{0pt}} @@ -545,13 +613,19 @@ % % \paragraph{和文フォントメトリックの選択} % -% ここではOTFパッケージのメトリックを元とした,|jfm-ujis.lua| メトリックを標準で使います。 +% ここではOTFパッケージのメトリックを元とした,\texttt{jfm-ujis.lua}メトリックを標準で使います。 % 古い\texttt{min10},\texttt{goth10}互換のメトリックを使いたいときは\texttt{mingoth} % というオプションを指定します。 -% p\TeX でよく利用される\texttt{jis}フォントメトリックと互換のメトリックを使いたい場合は, +% \pTeX でよく利用される\texttt{jis}フォントメトリックと互換のメトリックを使いたい場合は, % \texttt{ptexjis}というオプションを指定します。 % \texttt{winjis}メトリックは用済みのため,\texttt{winjis}オプションは無視されます。 % +% [2016-11-09] pLaTeX / upLaTeX を自動判別するオプション \texttt{autodetect-engine} を新設しました。 +% +% [2016-11-24 LTJ] \texttt{autodetect-engine} はLua\TeX-jaでは意味がないので警告を表示させます. +% +% [2018-07-30 LTJ] \texttt{uplatex} 指定時のエラーが正しく表示されなかったので修正しました. +% % \begin{macrocode} \newif\ifmingoth \mingothfalse @@ -560,9 +634,11 @@ \newif\ifptexjis \ptexjisfalse \DeclareOption{winjis}{% - \ClassWarningNoLine{\@currname}{The class option 'winjis' is obsolete}} + \ClassWarningNoLine{\jsc@clsname}{this class does not support `winjis' option}} \DeclareOption{uplatex}{% - \ClassWarningNoLine{\@currname}{The class option 'uplatex' is obsolete}} + \ClassError{\jsc@clsname}{this class does not support `uplatex' option}} +\DeclareOption{autodetect-engine}{% + \ClassWarningNoLine{\jsc@clsname}{this class does not support `autodetect-engine' option}} \DeclareOption{mingoth}{\mingothtrue} \DeclareOption{ptexjis}{\ptexjistrue} \DeclareOption{jis}{\jisfonttrue} @@ -570,7 +646,7 @@ % % \paragraph{papersizeスペシャルの利用} % -% |ltjsclasses| では |papersize| オプションの有無に関わらず, +% \texttt{ltjsclasses}では\texttt{papersize}オプションの有無に関わらず, % PDFのページサイズは適切に設定されるので,削除しました。 % % \paragraph{英語化} @@ -583,10 +659,13 @@ \DeclareOption{english}{\@englishtrue} % \end{macrocode} % -% \paragraph{ltjsreport相当} +% \paragraph{ltjsbookをltjsreportもどきに} % % オプション \texttt{report} を新設しました。 % +% [2017-02-13] 従来は「ltjsreport相当」をltjsbookの \texttt{report} オプションで提供して +% いましたが,新しくltjsreportクラスも作りました。どちらでもお好きな方を使ってください。 +% % \begin{macrocode} %<*book> \newif\if@report @@ -595,6 +674,18 @@ % % \end{macrocode} % +% \paragraph{\texttt{jslogo}パッケージの読み込み} +% +% \LaTeX 関連のロゴを再定義する\texttt{jslogo}パッケージを +% 読み込まないオプション\texttt{nojslogo}を新設しました。 +% \texttt{jslogo}オプションの指定で従来どおりの動作となります。 +% デフォルトは\texttt{jslogo}で,すなわちパッケージを読み込みます。 +% \begin{macrocode} +\newif\if@jslogo \@jslogotrue +\DeclareOption{jslogo}{\@jslogotrue} +\DeclareOption{nojslogo}{\@jslogofalse} +% \end{macrocode} +% % \paragraph{オプションの実行} % % デフォルトのオプションを実行します。 @@ -603,6 +694,7 @@ % \begin{macrocode} %
\ExecuteOptions{a4paper,oneside,onecolumn,notitlepage,final} %\ExecuteOptions{a4paper,twoside,onecolumn,titlepage,openright,final} +%\ExecuteOptions{a4paper,oneside,onecolumn,titlepage,openany,final} %\ExecuteOptions{a4paper,twoside,twocolumn,notitlepage,fleqn,final} %\ExecuteOptions{a4paper,twoside,twocolumn,notitlepage,final} \ProcessOptions @@ -628,7 +720,7 @@ % 基準となる行送りをポイント単位で表したものです。 % % \begin{macrocode} -%\if@slide\def\n@baseline{13}\else\def\n@baseline{16}\fi +%\if@slide\def\n@baseline{13}\else\def\n@baseline{16}\fi %\def\n@baseline{14.554375} %\def\n@baseline{14.897} % \end{macrocode} @@ -651,37 +743,37 @@ % % [2016-03-21 LTJ] |\mag| を使わないように全面的に書き換えました。 % |\ltjs@mpt| に「拡大率だけ大きくしたpt」の値が格納されます。 -% |bxjscls| と同様に,|\@ptsize| は |10pt|,~|11pt|,~|12pt| オプションが指定された時だけ +% \texttt{bxjscls}と同様に,|\@ptsize| は |10pt|,~|11pt|,~|12pt| オプションが指定された時だけ % 従来通り0,~1,~2と設定し,それ以外の場合は$-20$とすることにしました。 % |\inv@mag| はもはや定義していません。 % % [2016-03-26 LTJ] |\ltjs@magscale| に拡大率を格納した後,それを用いて |\ltjs@mpt| を % 設定するようにしました。 % -% [2016-07-08] |\js@mpt| および |\js@mmm| に,それぞれ1ptおよび1mmを拡大させた値を格納します。 +% [2016-07-08] |\jsc@mpt| および |\jsc@mmm| に,それぞれ1ptおよび1mmを拡大させた値を格納します。 % 以降のレイアウト指定ではこちらを使います。 % -% [2016-07-12 LTJ] |\ltjs@...|を本家に合わせて|\js@...|に名称変更しました。 +% [2016-07-12 LTJ] |\ltjs@...| を本家に合わせて |\jsc@...| に名称変更しました。 % \begin{macrocode} %<*kiyou> -\def\js@magscale{0.9769230} +\def\jsc@magscale{0.9769230} % -\newdimen\js@mpt -\newdimen\js@mmm -\js@mpt=\js@magscale\p@ -\js@mmm=\js@magscale mm -\ifdim\js@mpt<.92\p@ % 8pt, 9pt 指定時 +\newdimen\jsc@mpt +\newdimen\jsc@mmm +\jsc@mpt=\jsc@magscale\p@ +\jsc@mmm=\jsc@magscale mm +\ifdim\jsc@mpt<.92\p@ % 8pt, 9pt 指定時 \def\n@baseline{15}% \fi \newcommand{\@ptsize}{0} -\ifdim\js@mpt=1.0954\p@ \renewcommand{\@ptsize}{1}\else -\ifdim\js@mpt=1.2\p@ \renewcommand{\@ptsize}{2}\else +\ifdim\jsc@mpt=1.0954\p@ \renewcommand{\@ptsize}{1}\else +\ifdim\jsc@mpt=1.2\p@ \renewcommand{\@ptsize}{2}\else \renewcommand{\@ptsize}{-20}\fi\fi % \end{macrocode} % % \paragraph{オプティカルサイズの補正} % \leavevmode\par -% [2016-03-26 LTJ] |xreal|オプションの指定時には,|bxjscls|の|magstyle=xreal| +% [2016-03-26 LTJ] |xreal|オプションの指定時には,\texttt{bxjscls}の|magstyle=xreal| % オプションのように,オプティカルの補正を行うためにNFSSにパッチを当てます。 % パッチは,概ねmiscさんによる「js*.cls 同様の文字サイズ設定を % |\mag|によらずに行う方法:試案」 @@ -689,28 +781,39 @@ % 方法に沿っていますが,拡大/縮小するところの計算にはLuaを用いています。 % % なお,\TeX 内部で長さはsp単位の整数倍で表現されているので,数spの誤差は仕方がないです。 -% そのため,事前に|type1cm|パッケージを読みこんでおきます。 +% そのため,事前に\texttt{type1cm}パッケージを読みこんでおきます。 % -% [2016-03-28 LTJ] |\luafunction|を使うようにし,また本文のフォントサイズが10ptのときには +% [2016-03-28 LTJ] |\luafunction|を使うようにし,また本文のフォントサイズが10\,ptのときには % (不要なので)パッチを当てないことにしました。 % -% [2016-04-04 LTJ] NFSSへのパッチを修正. +% [2016-04-04 LTJ] NFSSへのパッチを修正。 +% +% [2017-01-23 LTJ] \LaTeXe\ 2017-01-01以降ではTUエンコーディングが標準なので, +% \texttt{type1cm}パッケージは読み込まないようにしました. +% +% [2017-02-17 LTJ] |\directlua|中で出力される数字のカテゴリーコードが12になるようにしました. +% この保証をしないと例えば\texttt{listings}パッケージで無限ループになります. +% +% [2018-07-02 LTJ] 10ptオプションが指定されており, +% 実際にはオプティカルサイズの補正が不要なときは「|xreal|オプションは指定されなかった」という +% 扱いにしておきます. % \begin{macrocode} -\if@ltjs@mag@xreal\RequirePackage{type1cm} -\ifdim\js@mpt=\p@\else +\ifjsc@mag@xreal +\ifdim\jsc@mpt=\p@\jsc@mag@xrealfalse\else \expandafter\let\csname OT1/cmr/m/n/10\endcsname\relax + \expandafter\let\csname TU/lmr/m/n/10\endcsname\relax \expandafter\let\csname OMX/cmex/m/n/10\endcsname\relax \newluafunction\ltjs@@magnify@font@calc \begingroup\catcode`\%=12\relax \directlua{ - local getdimen, mpt=tex.getdimen, tex.getdimen('js@mpt')/65536 + local getdimen, mpt=tex.getdimen, tex.getdimen('jsc@mpt')/65536 local t = lua.get_functions_table() t[\the\ltjs@@magnify@font@calc] = function() - tex.sprint(math.floor(0.5+mpt*getdimen('dimen@'))) + tex.sprint(-2,math.floor(0.5+mpt*getdimen('dimen@'))) end function luatexja.ltjs_unmagnify_fsize(a) local s = luatexja.print_scaled(math.floor(0.5+a/mpt*65536)) - tex.sprint( (s:match('%.0$')) and s:sub(1,-3) or s ) + tex.sprint(-2, (s:match('%.0$')) and s:sub(1,-3) or s ) end } \endgroup @@ -718,7 +821,7 @@ \def\@tempa{#1}\def\@tempb{#2}% \ifx\@tempb\@empty \edef\@tempb{ scaled\directlua{% - tex.sprint(math.floor(0.5+\js@magscale*1000)) + tex.sprint(-2,math.floor(0.5+\jsc@magscale*1000)) }}% \else \dimen@\@tempb\relax @@ -738,6 +841,38 @@ \fi\fi % \end{macrocode} % +% [2016-11-16] latex.ltx (ltspace.dtx)で定義されている |\smallskip| の, +% 単位 |pt| を |\jsc@mpt| に置き換えた |\jsc@smallskip| を定義します。 +% これは |\maketitle| で用いられます。 +% |\jsc@medskip| と |\jsc@bigskip| は必要ないのでコメントアウトしています。 +% +% \begin{macro}{\jsc@smallskip} +% \begin{macro}{\jsc@medskip} +% \begin{macro}{\jsc@bigskip} +% \begin{macrocode} +\def\jsc@smallskip{\vspace\jsc@smallskipamount} +%\def\jsc@medskip{\vspace\jsc@medskipamount} +%\def\jsc@bigskip{\vspace\jsc@bigskipamount} +% \end{macrocode} +% \end{macro} +% \end{macro} +% \end{macro} +% +% \begin{macro}{\jsc@smallskipamount} +% \begin{macro}{\jsc@medskipamount} +% \begin{macro}{\jsc@bigskipamount} +% \begin{macrocode} +\newskip\jsc@smallskipamount +\jsc@smallskipamount=3\jsc@mpt plus 1\jsc@mpt minus 1\jsc@mpt +%\newskip\jsc@medskipamount +%\jsc@medskipamount =6\jsc@mpt plus 2\jsc@mpt minus 2\jsc@mpt +%\newskip\jsc@bigskipamount +%\jsc@bigskipamoun =12\jsc@mpt plus 4\jsc@mpt minus 4\jsc@mpt +% \end{macrocode} +% \end{macro} +% \end{macro} +% \end{macro} +% % % \paragraph{PDFの用紙サイズの設定} % @@ -753,21 +888,32 @@ % % [2016-07-12 LTJ] luatex.defが新しくなったことに対応するaminophenさんのパッチを取り込みました。 % +% [2017-01-11] トンボオプションが指定されているとき「だけ」|\stockwidth|, +% |\stockheight|を定義するようにしました。 +% % \begin{macrocode} -\newlength{\stockwidth} -\newlength{\stockheight} -\setlength{\stockwidth}{\paperwidth} -\setlength{\stockheight}{\paperheight} \iftombow + \newlength{\stockwidth} + \newlength{\stockheight} + \setlength{\stockwidth}{\paperwidth} + \setlength{\stockheight}{\paperheight} \advance \stockwidth 2in \advance \stockheight 2in -\fi -\ifdefined\pdfpagewidth - \setlength{\pdfpagewidth}{\stockwidth} - \setlength{\pdfpageheight}{\stockheight} + \ifdefined\pdfpagewidth + \setlength{\pdfpagewidth}{\stockwidth} + \setlength{\pdfpageheight}{\stockheight} + \else + \setlength{\pagewidth}{\stockwidth} + \setlength{\pageheight}{\stockheight} + \fi \else - \setlength{\pagewidth}{\stockwidth} - \setlength{\pageheight}{\stockheight} + \ifdefined\pdfpagewidth + \setlength{\pdfpagewidth}{\paperwidth} + \setlength{\pdfpageheight}{\paperheight} + \else + \setlength{\pagewidth}{\paperwidth} + \setlength{\pageheight}{\paperheight} + \fi \fi % \end{macrocode} % \end{macro} @@ -792,38 +938,23 @@ % 一方,Lua\TeX-jaの提供するメトリックでは,そのようなことはありません。 % 公称10ポイントの和文フォントは,10ポイントで出力されます。 % -% この |ltjsclasses| でも,派生元の |jsclasses| と同じように, +% この\texttt{ltjsclasses}でも,派生元の\texttt{jsclasses}と同じように, % この公称10ポイントのフォントをここでは13級に縮小して % 使うことにします。そのためには,$13\,\textrm{Q}/10\,\textrm{pt}\simeq 0.924715$倍 % すればいいことになります。 % -% |\ltj@stdmcfont|,~|\ltj@stdgtfont| による、デフォルトで使われる明朝・ゴシックのフォントの -% 設定に対応しました。この2つの命令の値はユーザが日々の利用でその都度指定するものではなく、 -% 何らかの理由で非埋め込みフォントが正しく利用できない場合にのみ |luatexja.cfg| によって +% |\ltj@stdmcfont|,~|\ltj@stdgtfont| による,デフォルトで使われる明朝・ゴシックのフォントの +% 設定に対応しました。この2つの命令の値はユーザが日々の利用でその都度指定するものではなく, +% 何らかの理由で非埋め込みフォントが正しく利用できない場合にのみ\texttt{luatexja.cfg}によって % セットされるものです。 % -% [2014-07-26 LTJ] なお,現状のところ,縦組用JFMは |jfm-ujisv.lua| しか準備していません。 +% [2014-07-26 LTJ] なお,現状のところ,縦組用JFMは\texttt{jfm-ujisv.lua}しか準備していません。 +% +% [2016-03-21 LTJ] 拡大率の計算で1~ptを$1/72.27$インチでなく0.3514\,mmと間違えて扱っていたのを修正。 +% +% [2017-12-31] 和文スケール($1\,\mathrm{zw} \div \hbox{要求サイズ}$)を +% 表す実数値マクロ |\Cjascale| を定義しました。 % -% [2016-03-21 LTJ] 拡大率の計算で1~ptを$1/72.27$インチでなく0.3514~mmと間違えて扱っていたのを修正. -% \begin{macrocode} -%<*!jspf> -\expandafter\let\csname JY3/mc/m/n/10\endcsname\relax -\ifmingoth - \DeclareFontShape{JY3}{mc}{m}{n}{<-> s * [0.924715] \ltj@stdmcfont:jfm=min}{} - \DeclareFontShape{JY3}{gt}{m}{n}{<-> s * [0.924715] \ltj@stdgtfont:jfm=min}{} -\else - \ifptexjis - \DeclareFontShape{JY3}{mc}{m}{n}{<-> s * [0.924715] \ltj@stdmcfont:jfm=jis}{} - \DeclareFontShape{JY3}{gt}{m}{n}{<-> s * [0.924715] \ltj@stdgtfont:jfm=jis}{} - \else - \DeclareFontShape{JY3}{mc}{m}{n}{<-> s * [0.924715] \ltj@stdmcfont:jfm=ujis}{} - \DeclareFontShape{JY3}{gt}{m}{n}{<-> s * [0.924715] \ltj@stdgtfont:jfm=ujis}{} - \fi -\fi -\DeclareFontShape{JT3}{mc}{m}{n}{<-> s * [0.924715] \ltj@stdmcfont:jfm=ujisv}{} -\DeclareFontShape{JT3}{gt}{m}{n}{<-> s * [0.924715] \ltj@stdgtfont:jfm=ujisv}{} -% -% \end{macrocode} % % これにより,公称10ポイントの和文フォントを0.924715倍したことにより, % 約9.25ポイント, @@ -834,24 +965,27 @@ % 和文フォントをPostScriptの9ポイントにするために, % $0.9*72.27/72 \simeq 0.903375$ 倍します。 % +% [2018-09-23 LTJ] 実際の|\Cjascale|の定義はLua\TeX-jaの読み込み前に移動しました. +% こうすることによって「0.962216倍された和文フォント」という実際には使われない和文フォントを +% 読み込む必要がなくなります. +% +% +% 実際にフォントの再定義を行う部分です. +% +% [2018-09-23 LTJ] |\Cjascale|の設定を前倒ししたことに伴い,実際の再定義は +% \texttt{mingoth}, \texttt{ptexjis}のときしか必要なくなりました. +% % \begin{macrocode} -%<*jspf> \expandafter\let\csname JY3/mc/m/n/10\endcsname\relax \ifmingoth - \DeclareFontShape{JY3}{mc}{m}{n}{<-> s * [0.903375] \ltj@stdmcfont:jfm=min}{} - \DeclareFontShape{JY3}{gt}{m}{n}{<-> s * [0.903375] \ltj@stdgtfont:jfm=min}{} + \DeclareFontShape{JY3}{mc}{m}{n}{<-> s * [\Cjascale] \ltj@stdmcfont:jfm=min}{} + \DeclareFontShape{JY3}{gt}{m}{n}{<-> s * [\Cjascale] \ltj@stdgtfont:jfm=min}{} \else \ifptexjis - \DeclareFontShape{JY3}{mc}{m}{n}{<-> s * [0.903375] \ltj@stdmcfont:jfm=jis}{} - \DeclareFontShape{JY3}{gt}{m}{n}{<-> s * [0.903375] \ltj@stdgtfont:jfm=jis}{} - \else - \DeclareFontShape{JY3}{mc}{m}{n}{<-> s * [0.903375] \ltj@stdmcfont:jfm=ujis}{} - \DeclareFontShape{JY3}{gt}{m}{n}{<-> s * [0.903375] \ltj@stdgtfont:jfm=ujis}{} + \DeclareFontShape{JY3}{mc}{m}{n}{<-> s * [\Cjascale] \ltj@stdmcfont:jfm=jis}{} + \DeclareFontShape{JY3}{gt}{m}{n}{<-> s * [\Cjascale] \ltj@stdgtfont:jfm=jis}{} \fi \fi -\DeclareFontShape{JT3}{mc}{m}{n}{<-> s * [0.903375] \ltj@stdmcfont:jfm=ujisv}{} -\DeclareFontShape{JT3}{gt}{m}{n}{<-> s * [0.903375] \ltj@stdgtfont:jfm=ujisv}{} -% % \end{macrocode} % % 和文でイタリック体,斜体,サンセリフ体, @@ -873,11 +1007,16 @@ % [2004-11-03] |\rmfamily| も和文対応にしました。 % % [2016-01-30 LTJ] |\rmfamily|, |\sffamily|, |\ttfamily| の再定義をLua\TeX-ja -% カーネルに移動させたので,ここでは和文対応にするフラグ |\@ltj@match@family|\ +% カーネルに移動させたので,ここでは和文対応にするフラグ |\@ltj@match@family|\ % を有効にさせるだけでよいです。 +% +% [2018-06-09 LTJ] シリーズ|b|は同じ書体の|bx|と等価になるように宣言します。 +% % \begin{macrocode} \DeclareFontShape{JY3}{mc}{bx}{n}{<->ssub*gt/m/n}{} \DeclareFontShape{JY3}{gt}{bx}{n}{<->ssub*gt/m/n}{} +\DeclareFontShape{JY3}{mc}{b}{n}{<->ssub*gt/m/n}{} +\DeclareFontShape{JY3}{mc}{b}{n}{<->ssub*gt/m/n}{} \DeclareFontShape{JY3}{mc}{m}{it}{<->ssub*mc/m/n}{} \DeclareFontShape{JY3}{mc}{m}{sl}{<->ssub*mc/m/n}{} \DeclareFontShape{JY3}{mc}{m}{sc}{<->ssub*mc/m/n}{} @@ -885,29 +1024,39 @@ \DeclareFontShape{JY3}{gt}{m}{sl}{<->ssub*gt/m/n}{} \DeclareFontShape{JY3}{mc}{bx}{it}{<->ssub*gt/m/n}{} \DeclareFontShape{JY3}{mc}{bx}{sl}{<->ssub*gt/m/n}{} -% \DeclareFontShape{JT3}{mc}{bx}{n}{<->ssub*gt/m/n}{} -% \DeclareFontShape{JT3}{gt}{bx}{n}{<->ssub*gt/m/n}{} -%% \DeclareFontShape{JT3}{mc}{m}{it}{<->ssub*mc/m/n}{} -%% \DeclareFontShape{JT3}{mc}{m}{sl}{<->ssub*mc/m/n}{} -%% \DeclareFontShape{JT3}{mc}{m}{sc}{<->ssub*mc/m/n}{} -%% \DeclareFontShape{JT3}{gt}{m}{it}{<->ssub*gt/m/n}{} -%% \DeclareFontShape{JT3}{gt}{m}{sl}{<->ssub*gt/m/n}{} -%% \DeclareFontShape{JT3}{mc}{bx}{it}{<->ssub*gt/m/n}{} -%% \DeclareFontShape{JT3}{mc}{bx}{sl}{<->ssub*gt/m/n}{} +\DeclareFontShape{JY3}{mc}{b}{it}{<->ssub*gt/m/n}{} +\DeclareFontShape{JY3}{mc}{b}{sl}{<->ssub*gt/m/n}{} +\DeclareFontShape{JT3}{mc}{bx}{n}{<->ssub*gt/m/n}{} +\DeclareFontShape{JT3}{gt}{bx}{n}{<->ssub*gt/m/n}{} +\DeclareFontShape{JT3}{mc}{b}{n}{<->ssub*gt/m/n}{} +\DeclareFontShape{JT3}{mc}{b}{n}{<->ssub*gt/m/n}{} +\DeclareFontShape{JT3}{mc}{m}{it}{<->ssub*mc/m/n}{} +\DeclareFontShape{JT3}{mc}{m}{sl}{<->ssub*mc/m/n}{} +\DeclareFontShape{JT3}{mc}{m}{sc}{<->ssub*mc/m/n}{} +\DeclareFontShape{JT3}{gt}{m}{it}{<->ssub*gt/m/n}{} +\DeclareFontShape{JT3}{gt}{m}{sl}{<->ssub*gt/m/n}{} +\DeclareFontShape{JT3}{mc}{bx}{it}{<->ssub*gt/m/n}{} +\DeclareFontShape{JT3}{mc}{bx}{sl}{<->ssub*gt/m/n}{} +\DeclareFontShape{JT3}{mc}{b}{it}{<->ssub*gt/m/n}{} +\DeclareFontShape{JT3}{mc}{b}{sl}{<->ssub*gt/m/n}{} \renewcommand\jttdefault{\gtdefault}\@ltj@match@familytrue % \end{macrocode} %% % Lua\TeX-jaでは和文組版に伴うグルーはノードベースで挿入するようになり,また % 欧文・和文間のグルーとイタリック補正は干渉しないようになりました。 % まだ「和文の斜体」についてはLua\LaTeX カーネル側でまともな対応がされていませんが, -% |jsclasses.dtx| で行われていた |\textmc|, |\textgt| の再定義は不要のように思われます。 +% \texttt{jsclasses}で行われていた |\textmc|, |\textgt| の再定義は不要のように思われます。 % -% |jsclasses.dtx| 中で行われていた |\reDeclareMathAlphabet| の再定義は削除。 +% \texttt{jsclasses.dtx}中で行われていた |\reDeclareMathAlphabet| の再定義は削除。 +% また,Yue ZHANGさん作の\texttt{fixjfm}パッケージ対応のコードもLua\TeX-jaでは削除しています. % % \begin{macrocode} \AtBeginDocument{% - \reDeclareMathAlphabet{\mathrm}{\mathrm}{\mathmc} - \reDeclareMathAlphabet{\mathbf}{\mathbf}{\mathgt}}% + \unless\ifltj@disablejfam + \reDeclareMathAlphabet{\mathrm}{\mathrm}{\mathmc} + \reDeclareMathAlphabet{\mathbf}{\mathbf}{\mathgt} + \fi +}% % \end{macrocode} % % \begin{macro}{\textsterling} @@ -958,6 +1107,9 @@ % では |I watch TV\@.| と書くと V とピリオドのペアカーニングが効かなくなります。 % そこで,次のような定義に直し,|I watch TV.\@| と書くことにします。 % +% [2016-07-14] 2015-01-01の\LaTeX で,auxiliary filesに書き出されたときに +% スペースが食われないようにする修正が入りました。これに合わせて |{}| を補いました。 +% % \begin{macrocode} \def\@{\spacefactor3000{}} % \end{macrocode} @@ -992,7 +1144,7 @@ % 和文文字間のスペース |kanjiskip|, % 和文・欧文間のスペース |xkanjiskip| を変更しています。 % -% |kanjiskip| は |ltj-latex.sty| で |0pt plus 0.4pt minus 0.4pt| に +% |kanjiskip| は |ltj-latex.sty| で |0pt plus 0.4pt minus 0.5pt| に % 設定していますが, % これはそもそも文字サイズの変更に応じて変わるべきものです。 % それに,プラスになったりマイナスになったりするのは, @@ -1036,7 +1188,7 @@ \ltjsetkanjiskip\z@ plus .1\zw minus .01\zw \@tempskipa=\ltjgetparameter{xkanjiskip} \ifdim\@tempskipa>\z@ - \if@slide + \if@slide \ltjsetxkanjiskip .1em \else \ltjsetxkanjiskip .25em plus .15em minus .06em @@ -1045,12 +1197,12 @@ % \end{macrocode} % \end{macro} % -% \begin{macro}{\js@setfontsize} -% クラスファイルの内部では,拡大率も考慮した |\js@setfontsize| を +% \begin{macro}{\jsc@setfontsize} +% クラスファイルの内部では,拡大率も考慮した |\jsc@setfontsize| を % |\@setfontsize| の変わりに用いることにします。 % \begin{macrocode} -\def\js@setfontsize#1#2#3{% - \@setfontsize#1{#2\js@mpt}{#3\js@mpt}} +\def\jsc@setfontsize#1#2#3{% + \@setfontsize#1{#2\jsc@mpt}{#3\jsc@mpt}} % \end{macrocode} % \end{macro} % @@ -1126,8 +1278,8 @@ % \begin{macrocode} \renewcommand{\normalsize}{% \ltj@@ifnarrowbaselines - {\js@setfontsize\normalsize\@xpt\@xiipt}% - {\js@setfontsize\normalsize\@xpt{\n@baseline}}% + {\jsc@setfontsize\normalsize\@xpt\@xiipt}% + {\jsc@setfontsize\normalsize\@xpt{\n@baseline}}% % \end{macrocode} % % 数式の上のアキ(|\abovedisplayskip|), @@ -1140,9 +1292,9 @@ % いましたが,結局,微調節してみることにしました。 % % \begin{macrocode} - \abovedisplayskip 11\js@mpt \@plus3\js@mpt \@minus4\js@mpt - \abovedisplayshortskip \z@ \@plus3\js@mpt - \belowdisplayskip 9\js@mpt \@plus3\js@mpt \@minus4\js@mpt + \abovedisplayskip 11\jsc@mpt \@plus3\jsc@mpt \@minus4\jsc@mpt + \abovedisplayshortskip \z@ \@plus3\jsc@mpt + \belowdisplayskip 9\jsc@mpt \@plus3\jsc@mpt \@minus4\jsc@mpt \belowdisplayshortskip \belowdisplayskip % \end{macrocode} % @@ -1172,13 +1324,18 @@ % パラメータに実際の値を設定します。 % たとえば |\Cwd| は |\normalfont| の全角幅(|1\zw|)です。 % +% [2017-08-31] 基準とする文字を「全角空白」(EUCコード\texttt{0xA1A1})から +% 「漢」(JISコード\texttt{0x3441})へ変更しました。 +% +% [2017-09-19] 内部的に使った |\box0| を空にします。 % \begin{macrocode} -\setbox0\hbox{\char"3000}% 全角スペース +\setbox0\hbox{漢} \setlength\Cht{\ht0} \setlength\Cdp{\dp0} \setlength\Cwd{\wd0} \setlength\Cvs{\baselineskip} \setlength\Chs{\wd0} +\setbox0=\box\voidb@x % \end{macrocode} % \end{macro} % \end{macro} @@ -1190,21 +1347,21 @@ % % |\small| も |\normalsize| と同様に設定します。 % 行送りは,|\normalsize| が16ポイントなら, -% 割合からすれば $16 \times 0.9 = 14.4$ ポイントになりますが, +% 割合からすれば$16 \times 0.9 = 14.4$ポイントになりますが, % |\small| の使われ方を考えて,ここでは和文13ポイント, % 欧文11ポイントとします。 -% また,|\topsep| と |\parsep| は,元はそれぞれ $4 \pm 2$,$2 \pm 1$ +% また,|\topsep| と |\parsep| は,元はそれぞれ$4 \pm 2$,$2 \pm 1$ % ポイントでしたが,ここではゼロ(|\z@|)にしました。 % % \begin{macrocode} \newcommand{\small}{% \ltj@@ifnarrowbaselines -% {\js@setfontsize\small\@ixpt{11}}% -% {\js@setfontsize\small{8.8888}{11}}% -% {\js@setfontsize\small\@ixpt{13}}% -% {\js@setfontsize\small{8.8888}{13.2418}}% - \abovedisplayskip 9\js@mpt \@plus3\js@mpt \@minus4\js@mpt - \abovedisplayshortskip \z@ \@plus3\js@mpt +% {\jsc@setfontsize\small\@ixpt{11}}% +% {\jsc@setfontsize\small{8.8888}{11}}% +% {\jsc@setfontsize\small\@ixpt{13}}% +% {\jsc@setfontsize\small{8.8888}{13.2418}}% + \abovedisplayskip 9\jsc@mpt \@plus3\jsc@mpt \@minus4\jsc@mpt + \abovedisplayshortskip \z@ \@plus3\jsc@mpt \belowdisplayskip \abovedisplayskip \belowdisplayshortskip \belowdisplayskip \def\@listi{\leftmargin\leftmargini @@ -1223,12 +1380,12 @@ % \begin{macrocode} \newcommand{\footnotesize}{% \ltj@@ifnarrowbaselines -% {\js@setfontsize\footnotesize\@viiipt{9.5}}% -% {\js@setfontsize\footnotesize{8.8888}{11}}% -% {\js@setfontsize\footnotesize\@viiipt{11}}% -% {\js@setfontsize\footnotesize{8.8888}{13.2418}}% - \abovedisplayskip 6\js@mpt \@plus2\js@mpt \@minus3\js@mpt - \abovedisplayshortskip \z@ \@plus2\js@mpt +% {\jsc@setfontsize\footnotesize\@viiipt{9.5}}% +% {\jsc@setfontsize\footnotesize{8.8888}{11}}% +% {\jsc@setfontsize\footnotesize\@viiipt{11}}% +% {\jsc@setfontsize\footnotesize{8.8888}{13.2418}}% + \abovedisplayskip 6\jsc@mpt \@plus2\jsc@mpt \@minus3\jsc@mpt + \abovedisplayshortskip \z@ \@plus2\jsc@mpt \belowdisplayskip \abovedisplayskip \belowdisplayshortskip \belowdisplayskip \def\@listi{\leftmargin\leftmargini @@ -1257,21 +1414,21 @@ % [2004-11-03] |\HUGE| を追加。 % % \begin{macrocode} -\newcommand{\scriptsize}{\js@setfontsize\scriptsize\@viipt\@viiipt} -\newcommand{\tiny}{\js@setfontsize\tiny\@vpt\@vipt} +\newcommand{\scriptsize}{\jsc@setfontsize\scriptsize\@viipt\@viiipt} +\newcommand{\tiny}{\jsc@setfontsize\tiny\@vpt\@vipt} \if@twocolumn -% \newcommand{\large}{\js@setfontsize\large\@xiipt{\n@baseline}} -% \newcommand{\large}{\js@setfontsize\large{11.111}{\n@baseline}} +% \newcommand{\large}{\jsc@setfontsize\large\@xiipt{\n@baseline}} +% \newcommand{\large}{\jsc@setfontsize\large{11.111}{\n@baseline}} \else -% \newcommand{\large}{\js@setfontsize\large\@xiipt{17}} -% \newcommand{\large}{\js@setfontsize\large{11.111}{17}} +% \newcommand{\large}{\jsc@setfontsize\large\@xiipt{17}} +% \newcommand{\large}{\jsc@setfontsize\large{11.111}{17}} \fi -%\newcommand{\Large}{\js@setfontsize\Large\@xivpt{21}} -%\newcommand{\Large}{\js@setfontsize\Large{12.222}{21}} -\newcommand{\LARGE}{\js@setfontsize\LARGE\@xviipt{25}} -\newcommand{\huge}{\js@setfontsize\huge\@xxpt{28}} -\newcommand{\Huge}{\js@setfontsize\Huge\@xxvpt{33}} -\newcommand{\HUGE}{\js@setfontsize\HUGE{30}{40}} +%\newcommand{\Large}{\jsc@setfontsize\Large\@xivpt{21}} +%\newcommand{\Large}{\jsc@setfontsize\Large{12.222}{21}} +\newcommand{\LARGE}{\jsc@setfontsize\LARGE\@xviipt{25}} +\newcommand{\huge}{\jsc@setfontsize\huge\@xxpt{28}} +\newcommand{\Huge}{\jsc@setfontsize\Huge\@xxvpt{33}} +\newcommand{\HUGE}{\jsc@setfontsize\HUGE{30}{40}} % \end{macrocode} % \end{macro} % \end{macro} @@ -1345,10 +1502,10 @@ % \texttt{normal...} の付いた方は保存用です。 % % \begin{macrocode} -\setlength\lineskip{1\js@mpt} -\setlength\normallineskip{1\js@mpt} -\setlength\lineskiplimit{1\js@mpt} -\setlength\normallineskiplimit{1\js@mpt} +\setlength\lineskip{1\jsc@mpt} +\setlength\normallineskip{1\jsc@mpt} +\setlength\lineskiplimit{1\jsc@mpt} +\setlength\normallineskiplimit{1\jsc@mpt} % \end{macrocode} % \end{macro} % \end{macro} @@ -1445,12 +1602,18 @@ % 計算では |\headheight| ではなく |\topskip| を使う % ことにしました。 % +% [2016-08-17] 圏点やルビが一行目に来た場合に下がるのを防ぐた +% め,|\topskip| を10ptから1.38zwに増やしました。 +% |\headheight| は従来と同じ20ptのままとします。 +% +% [2016-08-17 LTJ] 1.38zwの代わりに1.38|\zh|にしています。 +% % \begin{macrocode} -\setlength\topskip{10\js@mpt} +\setlength\topskip{1.38\zh}%% from 10\jsc@mpt (2016-08-17) \if@slide - \setlength\headheight{0\js@mpt} + \setlength\headheight{0\jsc@mpt} \else - \setlength\headheight{2\topskip} + \setlength\headheight{20\jsc@mpt}%% from 2\topskip (2016-08-17); from \topskip (2003-06-26) \fi % \end{macrocode} % \end{macro} @@ -1476,7 +1639,7 @@ \fi \fi % -%\setlength\footskip{9\js@mmm} +%\setlength\footskip{9\jsc@mmm} %<*book> \if@report \setlength\footskip{0.03367\paperheight} @@ -1487,6 +1650,12 @@ \setlength\footskip{\z@} \fi % +%<*report> +\setlength\footskip{0.03367\paperheight} +\ifdim\footskip<\baselineskip + \setlength\footskip{\baselineskip} +\fi +% % \end{macrocode} % \end{macro} % @@ -1497,10 +1666,16 @@ % それ以外で25pt(約8.79mm)になっていました。 % ここでは article は |\footskip| $-$ |\topskip| としました。 % +% [2016-10-08] article の \texttt{slide} のとき, +% および book の非 \texttt{report} と kiyou のときに |\headsep| を +% 減らしそこねていたのを修正しました(2016-08-17での修正漏れ)。 +% % \begin{macrocode} %<*article> \if@slide - \setlength\headsep{0\js@mpt} + \setlength\headsep{0\jsc@mpt} + \addtolength\headsep{-\topskip}%% added (2016-10-08) + \addtolength\headsep{10\jsc@mpt}%% added (2016-10-08) \else \setlength\headsep{\footskip} \addtolength\headsep{-\topskip} @@ -1511,16 +1686,24 @@ \setlength\headsep{\footskip} \addtolength\headsep{-\topskip} \else - \setlength\headsep{6\js@mmm} + \setlength\headsep{6\jsc@mmm} + \addtolength\headsep{-\topskip}%% added (2016-10-08) + \addtolength\headsep{10\jsc@mpt}%% added (2016-10-08) \fi % +%<*report> +\setlength\headsep{\footskip} +\addtolength\headsep{-\topskip} +% %<*jspf> -\setlength\headsep{9\js@mmm} +\setlength\headsep{9\jsc@mmm} \addtolength\headsep{-\topskip} % %<*kiyou> -\setlength\headheight{0\js@mpt} -\setlength\headsep{0\js@mpt} +\setlength\headheight{0\jsc@mpt} +\setlength\headsep{0\jsc@mpt} +\addtolength\headsep{-\topskip}%% added (2016-10-08) +\addtolength\headsep{10\jsc@mpt}%% added (2016-10-08) % % \end{macrocode} % \end{macro} @@ -1562,7 +1745,7 @@ % % 書籍以外では本文領域の幅 |\textwidth| は |\fullwidth| と等しくします。 % |article| ではA4縦置きで49文字となります。 -% 某学会誌スタイルでは|50\zw|(25文字×2段)+段間8mmとします。 +% 某学会誌スタイルでは |50\zw|(25文字×2段)+段間8\,mmとします。 % % \begin{macrocode} %<*article> @@ -1580,7 +1763,7 @@ \setlength\fullwidth{0.76\paperwidth} \else \setlength\fullwidth{\paperwidth} - \addtolength\fullwidth{-36\js@mmm} + \addtolength\fullwidth{-36\jsc@mmm} \fi \if@twocolumn \@tempdima=2\zw \else \@tempdima=1\zw \fi \divide\fullwidth\@tempdima \multiply\fullwidth\@tempdima @@ -1593,9 +1776,15 @@ \fi \fi % +%<*report> +\setlength\fullwidth{0.76\paperwidth} +\if@twocolumn \@tempdima=2\zw \else \@tempdima=1\zw \fi +\divide\fullwidth\@tempdima \multiply\fullwidth\@tempdima +\setlength\textwidth{\fullwidth} +% %<*jspf> \setlength\fullwidth{50\zw} -\addtolength\fullwidth{8\js@mmm} +\addtolength\fullwidth{8\jsc@mmm} \setlength\textwidth{\fullwidth} % %<*kiyou> @@ -1628,25 +1817,49 @@ % [2003-06-26] |\headheight| を |\topskip| に直しました。 % 以前はこの二つは値が同じであったので,変化はないはずです。 % +% [2016-08-26] |\topskip| を10ptから1.38zwに増やしましたので, +% その分 |\textheight| を増やします(2016-08-17での修正漏れ)。 +% +% [2016-10-08] article の slide のときに |\headheight| はゼロ +% なので,さらに修正しました(2016-08-17での修正漏れ)。 +% % \begin{macrocode} -%<*article|book> +%<*article|book|report> \if@slide \setlength{\textheight}{0.95\paperheight} \else \setlength{\textheight}{0.83\paperheight} \fi -\addtolength{\textheight}{-\topskip} +\addtolength{\textheight}{-10\jsc@mpt}%% from -\topskip (2016-10-08); from -\headheight (2003-06-26) \addtolength{\textheight}{-\headsep} \addtolength{\textheight}{-\footskip} \addtolength{\textheight}{-\topskip} \divide\textheight\baselineskip \multiply\textheight\baselineskip -% +% %\setlength{\textheight}{51\baselineskip} %\setlength{\textheight}{47\baselineskip} \addtolength{\textheight}{\topskip} -\addtolength{\textheight}{0.1\js@mpt} -%\setlength{\mathindent}{10\js@mmm} +\addtolength{\textheight}{0.1\jsc@mpt} +%\setlength{\mathindent}{10\jsc@mmm} +% \end{macrocode} +% \end{macro} +% +% \begin{macro}{\flushbottom} +% +% [2016-07-18] |\textheight| に念のため0.1ポイント余裕を持たせて +% いるのと同様に,|\flushbottom| にも余裕を持たせます。 +% 元の\LaTeXe での完全な |\flushbottom| の定義は +%\begin{verbatim} +% \def\flushbottom{% +% \let\@textbottom\relax \let\@texttop\relax} +%\end{verbatim} +% ですが,次のようにします。 +% +% \begin{macrocode} +\def\flushbottom{% + \def\@textbottom{\vskip \z@ \@plus.1\jsc@mpt}% + \let\@texttop\relax} % \end{macrocode} % \end{macro} % @@ -1695,14 +1908,14 @@ % |\marginparwidth| は欄外の書き込みの横幅です。 % 外側マージンの幅(|\evensidemargin| $+$ 1インチ)から1センチを引き, % さらに |\marginparsep|(欄外の書き込みと本文のアキ)を引いた値に -% しました。最後に|1\zw|の整数倍に切り捨てます。 +% しました。最後に |1\zw| の整数倍に切り捨てます。 % % \begin{macrocode} \setlength\marginparwidth{\paperwidth} \addtolength\marginparwidth{-\oddsidemargin} \addtolength\marginparwidth{-1in} \addtolength\marginparwidth{-\textwidth} -\addtolength\marginparwidth{-10\js@mmm} +\addtolength\marginparwidth{-10\jsc@mmm} \addtolength\marginparwidth{-\marginparsep} \@tempdima=1\zw \divide\marginparwidth\@tempdima @@ -1721,13 +1934,18 @@ % [2011-10-03 LTJ] ここも |\oddsidemargin| のときと同様に |-\inv@mag in| ではなく % |-1in| にします。 % +% [2016-08-17] |\topskip| を10ptから1.38zwに直しましたが, +% |\topmargin| は従来の値から変わらないように調節しました。 +% …のつもりでしたが,|\textheight| を増やし忘れていたので +% 変わってしまっていました(2016-08-26修正済み)。 +% % \begin{macrocode} \setlength\topmargin{\paperheight} \addtolength\topmargin{-\textheight} \if@slide \addtolength\topmargin{-\headheight} \else - \addtolength\topmargin{-\topskip} + \addtolength\topmargin{-10\jsc@mpt}%% from -\topskip (2016-10-08); from -\headheight (2003-06-26) \fi \addtolength\topmargin{-\headsep} \addtolength\topmargin{-\footskip} @@ -1758,7 +1976,7 @@ % 和文の行送りを考えてもうちょっと大きくします。 % % \begin{macrocode} -\setlength{\skip\footins}{16\js@mpt \@plus 5\js@mpt \@minus 2\js@mpt} +\setlength{\skip\footins}{16\jsc@mpt \@plus 5\jsc@mpt \@minus 2\jsc@mpt} % \end{macrocode} % \end{macro} % @@ -1766,8 +1984,8 @@ % % フロート(図,表)関連のパラメータは\LaTeXe 本体で定義されていますが, % ここで設定変更します。本文ページ(本文とフロートが共存するページ) -% ちなみに,カウンタは内部では |\c@| を名前に冠したマクロになっています。 % とフロートだけのページで設定が異なります。 +% ちなみに,カウンタは内部では |\c@| を名前に冠したマクロになっています。 % % \begin{macro}{\c@topnumber} % @@ -1884,9 +2102,9 @@ % |\intextsep| は本文の途中に出力されるフロートと本文との距離です。 % % \begin{macrocode} -\setlength\floatsep {12\js@mpt \@plus 2\js@mpt \@minus 2\js@mpt} -\setlength\textfloatsep{20\js@mpt \@plus 2\js@mpt \@minus 4\js@mpt} -\setlength\intextsep {12\js@mpt \@plus 2\js@mpt \@minus 2\js@mpt} +\setlength\floatsep {12\jsc@mpt \@plus 2\jsc@mpt \@minus 2\jsc@mpt} +\setlength\textfloatsep{20\jsc@mpt \@plus 2\jsc@mpt \@minus 4\jsc@mpt} +\setlength\intextsep {12\jsc@mpt \@plus 2\jsc@mpt \@minus 2\jsc@mpt} % \end{macrocode} % \end{macro} % \end{macro} @@ -1898,8 +2116,8 @@ % 二段組のときの段抜きのフロートについての値です。 % % \begin{macrocode} -\setlength\dblfloatsep {12\js@mpt \@plus 2\js@mpt \@minus 2\js@mpt} -\setlength\dbltextfloatsep{20\js@mpt \@plus 2\js@mpt \@minus 4\js@mpt} +\setlength\dblfloatsep {12\jsc@mpt \@plus 2\jsc@mpt \@minus 2\jsc@mpt} +\setlength\dbltextfloatsep{20\jsc@mpt \@plus 2\jsc@mpt \@minus 4\jsc@mpt} % \end{macrocode} % \end{macro} % \end{macro} @@ -1914,9 +2132,9 @@ % |\@fpsep| はフロート間に入ります。 % % \begin{macrocode} -\setlength\@fptop{0\js@mpt \@plus 1fil} -\setlength\@fpsep{8\js@mpt \@plus 2fil} -\setlength\@fpbot{0\js@mpt \@plus 1fil} +\setlength\@fptop{0\jsc@mpt \@plus 1fil} +\setlength\@fpsep{8\jsc@mpt \@plus 2fil} +\setlength\@fpbot{0\jsc@mpt \@plus 1fil} % \end{macrocode} % \end{macro} % \end{macro} @@ -1929,20 +2147,79 @@ % 段抜きフロートについての値です。 % % \begin{macrocode} -\setlength\@dblfptop{0\js@mpt \@plus 1fil} -\setlength\@dblfpsep{8\js@mpt \@plus 2fil} -\setlength\@dblfpbot{0\js@mpt \@plus 1fil} +\setlength\@dblfptop{0\jsc@mpt \@plus 1fil} +\setlength\@dblfpsep{8\jsc@mpt \@plus 2fil} +\setlength\@dblfpbot{0\jsc@mpt \@plus 1fil} % \end{macrocode} % \end{macro} % \end{macro} % \end{macro} % +% \section{改ページ(日本語\TeX{}開発コミュニティ版のみ)}\label{sec:cleardoublepage} +% +% \begin{macro}{\pltx@cleartorightpage} +% \begin{macro}{\pltx@cleartoleftpage} +% \begin{macro}{\pltx@cleartooddpage} +% \begin{macro}{\pltx@cleartoevenpage} +% [2017-02-24] コミュニティ版\pLaTeX の標準クラス2017/02/15に合わせて, +% 同じ命令を追加しました。 +% \begin{enumerate} +% \item|\pltx@cleartorightpage|:右ページになるまでページを繰る命令 +% \item|\pltx@cleartoleftpage|:左ページになるまでページを繰る命令 +% \item|\pltx@cleartooddpage|:奇数ページになるまでページを繰る命令 +% \item|\pltx@cleartoevenpage|:偶数ページになるまでページを繰る命令 +% \end{enumerate} +% となっています。 +% +% \begin{macrocode} +%<*article|book|report> +\def\pltx@cleartorightpage{\clearpage\if@twoside + \unless\ifodd\numexpr\c@page+\ltjgetparameter{direction}\relax + \hbox{}\thispagestyle{empty}\newpage + \if@twocolumn\hbox{}\newpage\fi + \fi\fi} +\def\pltx@cleartoleftpage{\clearpage\if@twoside + \ifodd\numexpr\c@page+\ltjgetparameter{direction}\relax + \hbox{}\thispagestyle{empty}\newpage + \if@twocolumn\hbox{}\newpage\fi + \fi\fi} +\def\pltx@cleartooddpage{\clearpage\if@twoside + \ifodd\c@page\else + \hbox{}\thispagestyle{empty}\newpage + \if@twocolumn\hbox{}\newpage\fi + \fi\fi} +\def\pltx@cleartoevenpage{\clearpage\if@twoside + \ifodd\c@page + \hbox{}\thispagestyle{empty}\newpage + \if@twocolumn\hbox{}\newpage\fi + \fi\fi} +% +% \end{macrocode} +% \end{macro} +% \end{macro} +% \end{macro} +% \end{macro} +% +% \begin{macro}{\cleardoublepage} +% [2017-02-24] コミュニティ版\pLaTeX の標準クラス2017/02/15に合わせて, +% reportとbookクラスの場合に|\cleardoublepage|を再定義します。 +% \begin{macrocode} +%<*book|report> +\if@openleft + \let\cleardoublepage\pltx@cleartoleftpage +\else\if@openright + \let\cleardoublepage\pltx@cleartorightpage +\fi\fi +% +% \end{macrocode} +% \end{macro} +% % \section{ページスタイル}\label{sec:pagestyle} % % ページスタイルとして,\LaTeXe (欧文版)の標準クラス % では |empty|,|plain|,|headings|,|myheadings| があります。 % このうち |empty|,|plain| スタイルは\LaTeXe 本体 -% で定義されています。 +% で定義されています。 % % アスキーのクラスファイルでは |headnombre|,|footnombre|, % |bothstyle|,|jpl@in| が追加されていますが, @@ -2079,12 +2356,12 @@ % % \end{macrocode} % -% 次は book の場合です。 +% 次は book および report の場合です。 % [2011-05-10] しっぽ愛好家さん [qa:6370] のパッチを取り込ませていただきました % (北見さん [qa:55896] のご指摘ありがとうございます)。 % % \begin{macrocode} -%<*book> +%<*book|report> \newif\if@omit@number \def\ps@headings{% \let\@oddfoot\@empty @@ -2099,17 +2376,17 @@ \let\@mkboth\markboth \def\chaptermark##1{\markboth{% \ifnum \c@secnumdepth >\m@ne - \if@mainmatter +% \if@mainmatter \if@omit@number\else \@chapapp\thechapter\@chappos\hskip1\zw \fi - \fi +% \fi \fi ##1}{}}% \def\sectionmark##1{\markright{% \ifnum \c@secnumdepth >\z@ \thesection \hskip1\zw\fi ##1}}}% -% +% % \end{macrocode} % % 最後は学会誌の場合です。 @@ -2143,9 +2420,9 @@ \def\@oddhead{% \hbox to \fullwidth{\rightmark\hfil\thepage}\hss}% \let\@mkboth\@gobbletwo -% \let\chaptermark\@gobble +% \let\chaptermark\@gobble \let\sectionmark\@gobble -% \let\subsectionmark\@gobble +% \let\subsectionmark\@gobble } % \end{macrocode} % \end{macro} @@ -2221,8 +2498,12 @@ % 和文のものでは |\Large| になっていましたが,ここでは |\large| % にしました。 % +% [2016-11-16] スペーシングを元の |jsclasses| に合わせるため,|\smallskip| を +% |\jsc@smallskip| に置き換えました。|\smallskip| のままでは +% \texttt{nomag(*)} の場合にスケールしなくなり,レイアウトが変わってしまいます。 +% % \begin{macrocode} -%<*article|book|kiyou> +%<*article|book|report|kiyou> \if@titlepage \newcommand{\maketitle}{% \begin{titlepage}% @@ -2235,16 +2516,16 @@ \begin{center} \mbox{} \\[1\zw] \large - {\maybeblue\hrule height0\js@mpt depth2\js@mpt\relax}\par - \smallskip + {\maybeblue\hrule height0\jsc@mpt depth2\jsc@mpt\relax}\par + \jsc@smallskip \@title - \smallskip - {\maybeblue\hrule height0\js@mpt depth2\js@mpt\relax}\par + \jsc@smallskip + {\maybeblue\hrule height0\jsc@mpt depth2\jsc@mpt\relax}\par \vfill {\small \@author}% \end{center} \else - \vskip 60\js@mpt + \vskip 60\jsc@mpt \begin{center}% {\LARGE \@title \par}% \vskip 3em% @@ -2330,10 +2611,10 @@ {\large \@date}% \end{center}% \par\vskip 1.5em -% \ifvoid\@abstractbox\else\centerline{\box\@abstractbox}\vskip1.5em\fi +% \ifvoid\@abstractbox\else\centerline{\box\@abstractbox}\vskip1.5em\fi } \fi -% +% %<*jspf> \newcommand{\maketitle}{\par \begingroup @@ -2392,7 +2673,7 @@ \centerline{\box\@abstractbox} \ifx\@keywords\@undefined\else \vskip 1.5em - \centerline{\parbox{157\js@mmm}{\textsf{Keywords:}\\ \small\@keywords}} + \centerline{\parbox{157\jsc@mmm}{\textsf{Keywords:}\\ \small\@keywords}} \fi \vskip 1.5em} % @@ -2520,6 +2801,9 @@ % % [2011-10-05 LTJ] Lua\TeX-jaでは |\everyparhook| は不要なので削除。 % +% [2016-07-28] \texttt{slide}オプションと\texttt{twocolumn}オプションを +% 同時に指定した場合の罫線の位置を微調整しました。 +% % \begin{macrocode} \def\@xsect#1{% % 見出しの後ろの空きを \@tempskipa にセット @@ -2536,7 +2820,7 @@ \begingroup \@svsechd \endgroup \unskip \@tempskipa #1\relax - \hskip -\@tempskipa\@inhibitglue + \hskip -\@tempskipa\ltjfakeparbegin \else \clubpenalty \@clubpenalty \everypar{}% @@ -2547,7 +2831,9 @@ \@afterheading \fi \if@slide - {\vskip-6\js@mpt\maybeblue\hrule height0\js@mpt depth1\js@mpt\vskip7\js@mpt\relax}% + {\vskip\if@twocolumn-5\jsc@mpt\else-6\jsc@mpt\fi + \maybeblue\hrule height0\jsc@mpt depth1\jsc@mpt + \vskip\if@twocolumn 4\jsc@mpt\else 7\jsc@mpt\fi\relax}% \fi \par % 2000-12-18 \ignorespaces} @@ -2600,8 +2886,8 @@ % 番号を付けるかを決めるカウンタです。 % % \begin{macrocode} -%\setcounter{secnumdepth}{3} -%\setcounter{secnumdepth}{2} +%\setcounter{secnumdepth}{3} +%\setcounter{secnumdepth}{2} % \end{macrocode} % \end{macro} % @@ -2619,9 +2905,9 @@ % % \begin{macrocode} \newcounter{part} -%\newcounter{chapter} -%\newcounter{section}[chapter] -%\newcounter{section} +%\newcounter{chapter} +%\newcounter{section}[chapter] +%\newcounter{section} \newcounter{subsection}[section] \newcounter{subsubsection}[subsection] \newcounter{paragraph}[subsubsection] @@ -2659,14 +2945,14 @@ % % \begin{macrocode} \renewcommand{\thepart}{\@Roman\c@part} -%% \renewcommand{\thesection}{\@arabic\c@section} -%\renewcommand{\thesection}{\presectionname\@arabic\c@section\postsectionname} -%\renewcommand{\thesubsection}{\@arabic\c@section.\@arabic\c@subsection} -%<*book> +%% \renewcommand{\thesection}{\@arabic\c@section} +%\renewcommand{\thesection}{\presectionname\@arabic\c@section\postsectionname} +%\renewcommand{\thesubsection}{\@arabic\c@section.\@arabic\c@subsection} +%<*book|report> \renewcommand{\thechapter}{\@arabic\c@chapter} \renewcommand{\thesection}{\thechapter.\@arabic\c@section} \renewcommand{\thesubsection}{\thesection.\@arabic\c@subsection} -% +% \renewcommand{\thesubsubsection}{% \thesubsection.\@arabic\c@subsubsection} \renewcommand{\theparagraph}{% @@ -2695,8 +2981,8 @@ % [2003-03-02] |\@secapp| は外しました。 % % \begin{macrocode} -%\newcommand{\@chapapp}{\prechaptername} -%\newcommand{\@chappos}{\postchaptername} +%\newcommand{\@chapapp}{\prechaptername} +%\newcommand{\@chappos}{\postchaptername} % \end{macrocode} % \end{macro} % \end{macro} @@ -2710,14 +2996,19 @@ % % ページ番号をローマ数字にし,章番号を付けないようにします。 % +% [2017-03-05] |\frontmatter| と |\mainmatter| の2つの命令は, +% 改丁または改ページした後で |\pagenumbering{...}| でノンブルを1に +% リセットします。長い間 |\frontmatter| は \texttt{openany} のときに +% 単なる改ページとしていましたが,これではノンブルをリセットする際に +% 偶奇逆転が起こる場合がありました。\texttt{openany} かどうかに依らず +% 奇数ページまで繰るように修正することで,問題を解消しました。 +% 実は,\LaTeX の標準クラスでは1998年に修正されていた問題です +% (コミュニティ版\pLaTeX の標準クラス2017/03/05も参照)。 +% % \begin{macrocode} %<*book> \newcommand\frontmatter{% - \if@openright - \cleardoublepage - \else - \clearpage - \fi + \pltx@cleartooddpage \@mainmatterfalse \pagenumbering{roman}} % \end{macrocode} @@ -2729,11 +3020,7 @@ % % \begin{macrocode} \newcommand\mainmatter{% -% \if@openright - \cleardoublepage -% \else -% \clearpage -% \fi + \pltx@cleartooddpage \@mainmattertrue \pagenumbering{arabic}} % \end{macrocode} @@ -2745,11 +3032,13 @@ % % \begin{macrocode} \newcommand\backmatter{% - \if@openright + \if@openleft + \cleardoublepage + \else\if@openright \cleardoublepage \else \clearpage - \fi + \fi\fi \@mainmatterfalse} % % \end{macrocode} @@ -2781,29 +3070,31 @@ % \def\CMDB #1{....} % \chapter*{...} の定義 %\end{verbatim} % -% まず |book| クラス以外です。 +% まず |book| と |report| のクラス以外です。 % % \begin{macrocode} -%<*!book> +%<*!book&!report> \newcommand\part{% \if@noskipsec \leavevmode \fi \par \addvspace{4ex}% \if@english \@afterindentfalse \else \@afterindenttrue \fi \secdef\@part\@spart} -% +% % \end{macrocode} % -% |book| スタイルの場合は,少し複雑です。 +% |book| および |report| クラスの場合は,少し複雑です。 % % \begin{macrocode} -%<*book> +%<*book|report> \newcommand\part{% - \if@openright + \if@openleft + \cleardoublepage + \else\if@openright \cleardoublepage \else \clearpage - \fi + \fi\fi \thispagestyle{empty}% 欧文用標準スタイルでは plain \if@twocolumn \onecolumn @@ -2813,7 +3104,7 @@ \fi \null\vfil \secdef\@part\@spart} -% +% % \end{macrocode} % \end{macro} % @@ -2822,11 +3113,11 @@ % 部の見出しを出力します。 % |\bfseries| を |\headfont| に変えました。 % -% |book| クラス以外では |secnumdepth| が $-1$ より大きいとき +% |book| および |report| クラス以外では |secnumdepth| が $-1$ より大きいとき % 部番号を付けます。 % % \begin{macrocode} -%<*!book> +%<*!book&!report> \def\@part[#1]#2{% \ifnum \c@secnumdepth >\m@ne \refstepcounter{part}% @@ -2849,13 +3140,13 @@ \nobreak \vskip 3ex \@afterheading} -% +% % \end{macrocode} % -% |book| クラスでは |secnumdepth| が $-2$ より大きいとき部番号を付けます。 +% |book| および |report| クラスでは |secnumdepth| が $-2$ より大きいとき部番号を付けます。 % % \begin{macrocode} -%<*book> +%<*book|report> \def\@part[#1]#2{% \ifnum \c@secnumdepth >-2\relax \refstepcounter{part}% @@ -2870,11 +3161,11 @@ \normalfont \ifnum \c@secnumdepth >-2\relax \huge\headfont \prepartname\thepart\postpartname - \par\vskip20\js@mpt + \par\vskip20\jsc@mpt \fi \Huge \headfont #2\par}% \@endpart} -% +% % \end{macrocode} % \end{macro} % @@ -2883,7 +3174,7 @@ % 番号を付けない部です。 % % \begin{macrocode} -%<*!book> +%<*!book&!report> \def\@spart#1{{% \parindent \z@ \raggedright \interlinepenalty \@M @@ -2892,15 +3183,15 @@ \nobreak \vskip 3ex \@afterheading} -% -%<*book> +% +%<*book|report> \def\@spart#1{{% \centering \interlinepenalty \@M \normalfont \Huge \headfont #1\par}% \@endpart} -% +% % \end{macrocode} % \end{macro} % @@ -2910,18 +3201,25 @@ % 両面印刷のときは白ページを追加します。 % 二段組のときには,二段組に戻します。 % +% [2016-12-13] \texttt{openany} のときには白ページが追加されるのは変なので, +% その場合は追加しないようにしました。このバグは\LaTeX では +% classes.dtx v1.4b (2000/05/19) +% で修正されています。 +% % \begin{macrocode} -%<*book> +%<*book|report> \def\@endpart{\vfil\newpage \if@twoside - \null - \thispagestyle{empty}% - \newpage + \if@openleft %% added (2017/02/24) + \null\thispagestyle{empty}\newpage + \else\if@openright %% added (2016/12/13) + \null\thispagestyle{empty}\newpage + \fi\fi %% added (2016/12/13, 2017/02/24) \fi \if@restonecol \twocolumn \fi} -% +% % \end{macrocode} % \end{macro} % @@ -2935,9 +3233,10 @@ % 章見出しの上に図や表が来ないようにします。 % % \begin{macrocode} -%<*book> +%<*book|report> \newcommand{\chapter}{% - \if@openright\cleardoublepage\else\clearpage\fi + \if@openleft\cleardoublepage\else + \if@openright\cleardoublepage\else\clearpage\fi\fi \plainifnotempty % 元: \thispagestyle{plain} \global\@topnum\z@ \if@english \@afterindentfalse \else \@afterindenttrue \fi @@ -2955,7 +3254,7 @@ % \begin{macrocode} \def\@chapter[#1]#2{% \ifnum \c@secnumdepth >\m@ne - \if@mainmatter +% \if@mainmatter \refstepcounter{chapter}% \typeout{\@chapapp\thechapter\@chappos}% \addcontentsline{toc}{chapter}% @@ -2963,13 +3262,13 @@ % {\if@english\thechapter\else\@chapapp\thechapter\@chappos\fi}% {\@chapapp\thechapter\@chappos}% #1}% - \else\addcontentsline{toc}{chapter}{#1}\fi +% \else\addcontentsline{toc}{chapter}{#1}\fi \else \addcontentsline{toc}{chapter}{#1}% \fi \chaptermark{#1}% - \addtocontents{lof}{\protect\addvspace{10\js@mpt}}% - \addtocontents{lot}{\protect\addvspace{10\js@mpt}}% + \addtocontents{lof}{\protect\addvspace{10\jsc@mpt}}% + \addtocontents{lot}{\protect\addvspace{10\jsc@mpt}}% \if@twocolumn \@topnewpage[\@makechapterhead{#2}]% \else @@ -2989,11 +3288,11 @@ \vspace*{2\Cvs}% 欧文は50pt {\parindent \z@ \raggedright \normalfont \ifnum \c@secnumdepth >\m@ne - \if@mainmatter +% \if@mainmatter \huge\headfont \@chapapp\thechapter\@chappos \par\nobreak \vskip \Cvs % 欧文は20pt - \fi +% \fi \fi \interlinepenalty\@M \Huge \headfont #1\par\nobreak @@ -3029,7 +3328,7 @@ \interlinepenalty\@M \Huge \headfont #1\par\nobreak \vskip 3\Cvs}} % 欧文は40pt -% +% % \end{macrocode} % \end{macro} % @@ -3072,7 +3371,7 @@ % \begin{macrocode} \if@twocolumn \newcommand{\subsection}{\@startsection{subsection}{2}{\z@}% - {\z@}{\z@}% + {\z@}{\if@slide .4\Cvs \else \z@ \fi}% {\normalfont\normalsize\headfont}} \else \newcommand{\subsection}{\@startsection{subsection}{2}{\z@}% @@ -3085,48 +3384,70 @@ % \end{macro} % % \begin{macro}{\subsubsection} +% +% [2016-07-22] \texttt{slide}オプション指定時に |\subsubsection| の文字列 +% と罫線が重なる問題に対処しました(forum:1982)。 +% % \begin{macrocode} \if@twocolumn \newcommand{\subsubsection}{\@startsection{subsubsection}{3}{\z@}% - {\z@}{\z@}% + {\z@}{\if@slide .4\Cvs \else \z@ \fi}% {\normalfont\normalsize\headfont}} \else \newcommand{\subsubsection}{\@startsection{subsubsection}{3}{\z@}% {\Cvs \@plus.5\Cdp \@minus.2\Cdp}% - {\z@}% + {\if@slide .5\Cvs \@plus.3\Cdp \else \z@ \fi}% {\normalfont\normalsize\headfont}} \fi % \end{macrocode} % \end{macro} % % \begin{macro}{\paragraph} +% \begin{macro}{\jsParagraphMark} % % 見出しの後ろで改行されません。 % +% [2016-11-16] 従来は |\paragraph| の最初に出るマークを「■」に固定して +% いましたが,このマークを変更可能にするため |\jsParagraphMark| というマクロ +% に切り出しました。これで,たとえば +%\begin{verbatim} +% \renewcommand{\jsParagraphMark}{★} +%\end{verbatim} +% とすれば「★」に変更できますし,マークを空にすることも容易です。 +% なお,某学会クラスでは従来どおりマークは付きません。 +% % \begin{macrocode} +%\newcommand{\jsParagraphMark}{■} \if@twocolumn \newcommand{\paragraph}{\@startsection{paragraph}{4}{\z@}% - {\z@}{-1\zw}% 改行せず 1\zw のアキ + {\z@}{\if@slide .4\Cvs \else -1\zw\fi}% 改行せず 1\zw のアキ % {\normalfont\normalsize\headfont}} -% {\normalfont\normalsize\headfont ■}} +% {\normalfont\normalsize\headfont\jsParagraphMark}} \else \newcommand{\paragraph}{\@startsection{paragraph}{4}{\z@}% {0.5\Cvs \@plus.5\Cdp \@minus.2\Cdp}% - {-1\zw}% 改行せず 1\zw のアキ + {\if@slide .5\Cvs \@plus.3\Cdp \else -1\zw\fi}% 改行せず 1\zw のアキ % {\normalfont\normalsize\headfont}} -% {\normalfont\normalsize\headfont ■}} +% {\normalfont\normalsize\headfont\jsParagraphMark}} \fi % \end{macrocode} % \end{macro} +% \end{macro} % % \begin{macro}{\subparagraph} % % 見出しの後ろで改行されません。 % % \begin{macrocode} -\newcommand{\subparagraph}{\@startsection{subparagraph}{5}{\z@}% - {\z@}{-1\zw}% - {\normalfont\normalsize\headfont}} +\if@twocolumn + \newcommand{\subparagraph}{\@startsection{subparagraph}{5}{\z@}% + {\z@}{\if@slide .4\Cvs \@plus.3\Cdp \else -1\zw\fi}% + {\normalfont\normalsize\headfont}} +\else + \newcommand{\subparagraph}{\@startsection{subparagraph}{5}{\z@}% + {\z@}{\if@slide .5\Cvs \@plus.3\Cdp \else -1\zw\fi}% + {\normalfont\normalsize\headfont}} +\fi % \end{macrocode} % \end{macro} % @@ -3438,7 +3759,7 @@ \rightmargin=0pt \leftmargin=5\zw}\item[]}{\end{list}\vspace{\baselineskip}} % -%<*article|kiyou> +%<*article|report|kiyou> \newbox\@abstractbox \if@titlepage \newenvironment{abstract}{% @@ -3487,14 +3808,14 @@ \endlist \fi} \fi -% +% %<*jspf> \newbox\@abstractbox \newenvironment{abstract}{% \global\setbox\@abstractbox\hbox\bgroup - \begin{minipage}[b]{157\js@mmm}{\sffamily Abstract}\par + \begin{minipage}[b]{157\jsc@mmm}{\sffamily Abstract}\par \small - \if@english \parindent6\js@mmm \else \parindent1\zw \fi}% + \if@english \parindent6\jsc@mmm \else \parindent1\zw \fi}% {\end{minipage}\egroup} % % \end{macrocode} @@ -3512,7 +3833,7 @@ %\newbox\@keywordsbox %\newenvironment{keywords}{% % \global\setbox\@keywordsbox\hbox\bgroup -% \begin{minipage}[b]{157\js@mmm}{\sffamily Keywords:}\par +% \begin{minipage}[b]{157\jsc@mmm}{\sffamily Keywords:}\par % \small\parindent0\zw}% % {\end{minipage}\egroup} % @@ -3595,16 +3916,24 @@ % % タイトルを独立のページに出力するのに使われます。 % +% [2017-02-24] コミュニティ版\pLaTeX の標準クラス2017/02/15に合わせて, +% bookクラスでタイトルを必ず奇数ページに送るようにしました。といっても, +% 横組クラスしかありませんでしたので,従来の挙動は何も変わっていません。 +% また,book以外の場合のページ番号のリセットもコミュニティ版\pLaTeX の +% 標準クラス2017/02/15に合わせましたが,こちらも片面印刷あるいは +% 独立のタイトルページを作らないクラスばかりでしたので,従来の挙動は +% 何も変わらずに済みました。 +% % \begin{macrocode} \newenvironment{titlepage}{% -% \cleardoublepage +% \pltx@cleartooddpage %% 2017-02-24 \if@twocolumn \@restonecoltrue\onecolumn \else \@restonecolfalse\newpage \fi \thispagestyle{empty}% - \setcounter{page}\@ne + \ifodd\c@page\setcounter{page}\@ne\else\setcounter{page}\z@\fi }% {\if@restonecol\twocolumn \else \newpage \fi \if@twoside\else @@ -3620,7 +3949,7 @@ % 本文と付録を分離するコマンドです。 % % \begin{macrocode} -%<*!book> +%<*!book&!report> \newcommand{\appendix}{\par \setcounter{section}{0}% \setcounter{subsection}{0}% @@ -3629,15 +3958,15 @@ % \gdef\thesection{\@Alph\c@section}% [2003-03-02] \gdef\thesection{\presectionname\@Alph\c@section\postsectionname}% \gdef\thesubsection{\@Alph\c@section.\@arabic\c@subsection}} -% -%<*book> +% +%<*book|report> \newcommand{\appendix}{\par \setcounter{chapter}{0}% \setcounter{section}{0}% \gdef\@chapapp{\appendixname}% \gdef\@chappos{}% \gdef\thechapter{\@Alph\c@chapter}} -% +% % \end{macrocode} % \end{macro} % @@ -3650,7 +3979,7 @@ % |array| 環境の列間には |\arraycolsep| の2倍の幅の空きが入ります。 % % \begin{macrocode} -\setlength\arraycolsep{5\js@mpt} +\setlength\arraycolsep{5\jsc@mpt} % \end{macrocode} % \end{macro} % @@ -3659,7 +3988,7 @@ % |tabular| 環境の列間には |\tabcolsep| の2倍の幅の空きが入ります。 % % \begin{macrocode} -\setlength\tabcolsep{6\js@mpt} +\setlength\tabcolsep{6\jsc@mpt} % \end{macrocode} % \end{macro} % @@ -3668,7 +3997,7 @@ % |array|,|tabular| 環境内の罫線の幅です。 % % \begin{macrocode} -\setlength\arrayrulewidth{.4\js@mpt} +\setlength\arrayrulewidth{.4\jsc@mpt} % \end{macrocode} % \end{macro} % @@ -3677,7 +4006,7 @@ % |array|,|tabular| 環境での二重罫線間のアキです。 % % \begin{macrocode} -\setlength\doublerulesep{2\js@mpt} +\setlength\doublerulesep{2\jsc@mpt} % \end{macrocode} % \end{macro} % @@ -3716,8 +4045,8 @@ % |\fbox|,|\framebox| の罫線の幅です。 % % \begin{macrocode} -\setlength\fboxsep{3\js@mpt} -\setlength\fboxrule{.4\js@mpt} +\setlength\fboxsep{3\jsc@mpt} +\setlength\fboxrule{.4\jsc@mpt} % \end{macrocode} % \end{macro} % \end{macro} @@ -3729,12 +4058,12 @@ % 数式番号を出力するコマンドです。 % % \begin{macrocode} -%\renewcommand \theequation {\@arabic\c@equation} -%<*book> +%\renewcommand \theequation {\@arabic\c@equation} +%<*book|report> \@addtoreset{equation}{chapter} \renewcommand\theequation {\ifnum \c@chapter>\z@ \thechapter.\fi \@arabic\c@equation} -% +% % \end{macrocode} % \end{macro} % @@ -3798,15 +4127,15 @@ % 図番号を出力するコマンドです。 % % \begin{macrocode} -%<*!book> +%<*!book&!report> \newcounter{figure} \renewcommand \thefigure {\@arabic\c@figure} -% -%<*book> +% +%<*book|report> \newcounter{figure}[chapter] \renewcommand \thefigure {\ifnum \c@chapter>\z@ \thechapter.\fi \@arabic\c@figure} -% +% % \end{macrocode} % \end{macro} % \end{macro} @@ -3857,15 +4186,15 @@ % ここではオリジナルのままにしています。 % % \begin{macrocode} -%<*!book> +%<*!book&!report> \newcounter{table} \renewcommand\thetable{\@arabic\c@table} -% -%<*book> +% +%<*book|report> \newcounter{table}[chapter] \renewcommand \thetable {\ifnum \c@chapter>\z@ \thechapter.\fi \@arabic\c@table} -% +% % \end{macrocode} % \end{macro} % \end{macro} @@ -3926,8 +4255,8 @@ % \begin{macrocode} \newlength\abovecaptionskip \newlength\belowcaptionskip -\setlength\abovecaptionskip{5\js@mpt} % 元: 10\p@ -\setlength\belowcaptionskip{5\js@mpt} % 元: 0\p@ +\setlength\abovecaptionskip{5\jsc@mpt} % 元: 10\p@ +\setlength\belowcaptionskip{5\jsc@mpt} % 元: 0\p@ % \end{macrocode} % \end{macro} % \end{macro} @@ -3942,13 +4271,13 @@ % \begin{verbatim} % ! Missing number, treated as zero. % \end{verbatim} -% +% % % \begin{macrocode} %<*!jspf> % \long\def\@makecaption#1#2{{\small -% \advance\leftskip10\js@mmm -% \advance\rightskip10\js@mmm +% \advance\leftskip10\jsc@mmm +% \advance\rightskip10\jsc@mmm % \vskip\abovecaptionskip % \sbox\@tempboxa{#1{\hskip1\zw}#2}% % \ifdim \wd\@tempboxa >\hsize @@ -3978,9 +4307,9 @@ \itemsep \z@ \itemindent \z@ \labelsep \z@ - \labelwidth 11\js@mmm + \labelwidth 11\jsc@mmm \listparindent\z@ - \leftmargin 11\js@mmm}\item\relax #2\endlist} + \leftmargin 11\jsc@mmm}\item\relax #2\endlist} \else \global \@minipagefalse \hb@xt@\hsize{\hfil\box\@tempboxa\hfil}% @@ -3997,6 +4326,48 @@ % これらは互換性のためのもので, % できるだけ |\text...| と |\math...| を使ってください。 % +% [2016-07-15] KOMA-Script中の |\scr@DeclareOldFontCommand| に倣い, +% これらの命令を使うときには警告を発することにしました。 +% +% [2016-07-16] 警告を最初の一回だけ発することにしました。また, +% 例外的に警告を出さないようにするスイッチも付けます。 +% +% \begin{macro}{\if@jsc@warnoldfontcmd} +% \begin{macro}{\if@jsc@warnoldfontcmdexception} +% \begin{macrocode} +\newif\if@jsc@warnoldfontcmd +\@jsc@warnoldfontcmdtrue +\newif\if@jsc@warnoldfontcmdexception +\@jsc@warnoldfontcmdexceptionfalse +% \end{macrocode} +% \end{macro} +% \end{macro} +% +% \begin{macro}{\jsc@DeclareOldFontCommand} +% \begin{macrocode} +\newcommand*{\jsc@DeclareOldFontCommand}[3]{% + \DeclareOldFontCommand{#1}{% + \jsc@warnoldfontcmd{#1}#2% + }{% + \jsc@warnoldfontcmd{#1}#3% + }% +} +\DeclareRobustCommand*{\jsc@warnoldfontcmd}[1]{% + \if@jsc@warnoldfontcmdexception\else\if@jsc@warnoldfontcmd + \ClassWarning{\jsc@clsname}{% + deprecated old font command `\string#1' used.\MessageBreak + You should note, that since 1994 LaTeX2e provides a\MessageBreak + new font selection scheme called NFSS2 with several\MessageBreak + new, combinable font commands. This \jsc@clsname\MessageBreak + class has defined the old font commands like\MessageBreak + `\string#1' only for compatibility% + }% + \global\@jsc@warnoldfontcmdfalse + \fi\fi +} +% \end{macrocode} +% \end{macro} +% % \begin{macro}{\mc} % \begin{macro}{\gt} % \begin{macro}{\rm} @@ -4006,11 +4377,11 @@ % フォントファミリを変更します。 % % \begin{macrocode} -\DeclareOldFontCommand{\mc}{\normalfont\mcfamily}{\mathmc} -\DeclareOldFontCommand{\gt}{\normalfont\gtfamily}{\mathgt} -\DeclareOldFontCommand{\rm}{\normalfont\rmfamily}{\mathrm} -\DeclareOldFontCommand{\sf}{\normalfont\sffamily}{\mathsf} -\DeclareOldFontCommand{\tt}{\normalfont\ttfamily}{\mathtt} +\jsc@DeclareOldFontCommand{\mc}{\normalfont\mcfamily}{\mathmc} +\jsc@DeclareOldFontCommand{\gt}{\normalfont\gtfamily}{\mathgt} +\jsc@DeclareOldFontCommand{\rm}{\normalfont\rmfamily}{\mathrm} +\jsc@DeclareOldFontCommand{\sf}{\normalfont\sffamily}{\mathsf} +\jsc@DeclareOldFontCommand{\tt}{\normalfont\ttfamily}{\mathtt} % \end{macrocode} % \end{macro} % \end{macro} @@ -4024,7 +4395,7 @@ % コマンドは |\mdseries| です。 % % \begin{macrocode} -\DeclareOldFontCommand{\bf}{\normalfont\bfseries}{\mathbf} +\jsc@DeclareOldFontCommand{\bf}{\normalfont\bfseries}{\mathbf} % \end{macrocode} % \end{macro} % @@ -4038,9 +4409,9 @@ % 通常のアップライト体に戻すコマンドは |\upshape| です。 % % \begin{macrocode} -\DeclareOldFontCommand{\it}{\normalfont\itshape}{\mathit} -\DeclareOldFontCommand{\sl}{\normalfont\slshape}{\@nomath\sl} -\DeclareOldFontCommand{\sc}{\normalfont\scshape}{\@nomath\sc} +\jsc@DeclareOldFontCommand{\it}{\normalfont\itshape}{\mathit} +\jsc@DeclareOldFontCommand{\sl}{\normalfont\slshape}{\@nomath\sl} +\jsc@DeclareOldFontCommand{\sc}{\normalfont\scshape}{\@nomath\sc} % \end{macrocode} % \end{macro} % \end{macro} @@ -4122,8 +4493,8 @@ \newcommand\@pnumwidth{1.55em} \newcommand\@tocrmarg{2.55em} \newcommand\@dotsep{4.5} -%\setcounter{tocdepth}{2} -%\setcounter{tocdepth}{1} +%\setcounter{tocdepth}{2} +%\setcounter{tocdepth}{1} % \end{macrocode} % \end{macro} % \end{macro} @@ -4136,18 +4507,18 @@ % % 目次を生成します。 % -% \begin{macro}{\js@tocl@width} +% \begin{macro}{\jsc@tocl@width} % % [2013-12-30] |\prechaptername| などから見積もった目次のラベルの長さです。(by ts) % % \begin{macrocode} -\newdimen\js@tocl@width +\newdimen\jsc@tocl@width \newcommand{\tableofcontents}{% -%<*book> - \settowidth\js@tocl@width{\headfont\prechaptername\postchaptername}% +%<*book|report> + \settowidth\jsc@tocl@width{\headfont\prechaptername\postchaptername}% \settowidth\@tempdima{\headfont\appendixname}% - \ifdim\js@tocl@width<\@tempdima \setlength\js@tocl@width{\@tempdima}\fi - \ifdim\js@tocl@width<2\zw \divide\js@tocl@width by 2 \advance\js@tocl@width 1\zw\fi + \ifdim\jsc@tocl@width<\@tempdima \setlength\jsc@tocl@width{\@tempdima}\fi + \ifdim\jsc@tocl@width<2\zw \divide\jsc@tocl@width by 2 \advance\jsc@tocl@width 1\zw\fi \if@twocolumn \@restonecoltrue\onecolumn \else @@ -4155,17 +4526,17 @@ \fi \chapter*{\contentsname}% \@mkboth{\contentsname}{}% -% -%<*!book> - \settowidth\js@tocl@width{\headfont\presectionname\postsectionname}% +% +%<*!book&!report> + \settowidth\jsc@tocl@width{\headfont\presectionname\postsectionname}% \settowidth\@tempdima{\headfont\appendixname}% - \ifdim\js@tocl@width<\@tempdima\relax\setlength\js@tocl@width{\@tempdima}\fi - \ifdim\js@tocl@width<2\zw \divide\js@tocl@width by 2 \advance\js@tocl@width 1\zw\fi + \ifdim\jsc@tocl@width<\@tempdima\relax\setlength\jsc@tocl@width{\@tempdima}\fi + \ifdim\jsc@tocl@width<2\zw \divide\jsc@tocl@width by 2 \advance\jsc@tocl@width 1\zw\fi \section*{\contentsname}% \@mkboth{\contentsname}{\contentsname}% -% +% \@starttoc{toc}% -% \if@restonecol\twocolumn\fi +% \if@restonecol\twocolumn\fi } % \end{macrocode} % \end{macro}\end{macro} @@ -4177,9 +4548,9 @@ % \begin{macrocode} \newcommand*{\l@part}[2]{% \ifnum \c@tocdepth >-2\relax -% \addpenalty\@secpenalty -% \addpenalty{-\@highpenalty}% - \addvspace{2.25em \@plus\js@mpt}% +% \addpenalty\@secpenalty +% \addpenalty{-\@highpenalty}% + \addvspace{2.25em \@plus\jsc@mpt}% \begingroup \parindent \z@ % \@pnumwidth should be \@tocrmarg @@ -4191,8 +4562,8 @@ \setlength\@lnumwidth{4\zw}% #1\hfil \hb@xt@\@pnumwidth{\hss #2}}\par \nobreak -% \global\@nobreaktrue -% \everypar{\global\@nobreakfalse\everypar{}}% +% \global\@nobreaktrue +% \everypar{\global\@nobreakfalse\everypar{}}% \endgroup \fi} % \end{macrocode} @@ -4202,15 +4573,15 @@ % % 章の目次です。|\@lnumwidth| を |4.683\zw| に増やしました。 % -% [2013-12-30] |\@lnumwidth| を |\js@tocl@width| から +% [2013-12-30] |\@lnumwidth| を |\jsc@tocl@width| から % 決めるようにしてみました。(by ts) % % \begin{macrocode} -%<*book> +%<*book|report> \newcommand*{\l@chapter}[2]{% \ifnum \c@tocdepth >\m@ne \addpenalty{-\@highpenalty}% - \addvspace{1.0em \@plus\js@mpt} + \addvspace{1.0em \@plus\jsc@mpt} % \vskip 1.0em \@plus\p@ % book.clsでは↑がこうなっている \begingroup \parindent\z@ @@ -4219,13 +4590,13 @@ \parfillskip-\rightskip \leavevmode\headfont % \if@english\setlength\@lnumwidth{5.5em}\else\setlength\@lnumwidth{4.683\zw}\fi - \setlength\@lnumwidth{\js@tocl@width}\advance\@lnumwidth 2.683\zw + \setlength\@lnumwidth{\jsc@tocl@width}\advance\@lnumwidth 2.683\zw \advance\leftskip\@lnumwidth \hskip-\leftskip #1\nobreak\hfil\nobreak\hbox to\@pnumwidth{\hss#2}\par \penalty\@highpenalty \endgroup \fi} -% +% % \end{macrocode} % \end{macro} % @@ -4234,11 +4605,11 @@ % 節の目次です。 % % \begin{macrocode} -%<*!book> +%<*!book&!report> \newcommand*{\l@section}[2]{% \ifnum \c@tocdepth >\z@ \addpenalty{\@secpenalty}% - \addvspace{1.0em \@plus\js@mpt}% + \addvspace{1.0em \@plus\jsc@mpt}% \begingroup \parindent\z@ % \rightskip\@pnumwidth @@ -4246,22 +4617,22 @@ \parfillskip-\rightskip \leavevmode\headfont %\setlength\@lnumwidth{4\zw}% 元1.5em [2003-03-02] - \setlength\@lnumwidth{\js@tocl@width}\advance\@lnumwidth 2\zw + \setlength\@lnumwidth{\jsc@tocl@width}\advance\@lnumwidth 2\zw \advance\leftskip\@lnumwidth \hskip-\leftskip #1\nobreak\hfil\nobreak\hbox to\@pnumwidth{\hss#2}\par \endgroup \fi} -% +% % \end{macrocode} % % インデントと幅はそれぞれ1.5em,2.3emでしたが, % |1\zw|,|3.683\zw|に変えました。 % % \begin{macrocode} -% % \newcommand*{\l@section}{\@dottedtocline{1}{1\zw}{3.683\zw}} +% % \newcommand*{\l@section}{\@dottedtocline{1}{1\zw}{3.683\zw}} % \end{macrocode} % -% [2013-12-30] 上のインデントは |\js@tocl@width| から決めるように +% [2013-12-30] 上のインデントは |\jsc@tocl@width| から決めるように % しました。(by ts) % % \end{macro} @@ -4274,11 +4645,11 @@ % さらに下位レベルの目次項目の体裁です。 % あまり使ったことがありませんので,要修正かもしれません。 % -% [2013-12-30] ここも |\js@tocl@width| から決めるように +% [2013-12-30] ここも |\jsc@tocl@width| から決めるように % してみました。(by ts) % % \begin{macrocode} -%<*!book> +%<*!book&!report> % \newcommand*{\l@subsection} {\@dottedtocline{2}{1.5em}{2.3em}} % \newcommand*{\l@subsubsection}{\@dottedtocline{3}{3.8em}{3.2em}} % \newcommand*{\l@paragraph} {\@dottedtocline{4}{7.0em}{4.1em}} @@ -4290,39 +4661,39 @@ % \newcommand*{\l@subparagraph} {\@dottedtocline{5}{4\zw}{3\zw}} % \newcommand*{\l@subsection}{% - \@tempdima\js@tocl@width \advance\@tempdima -1\zw + \@tempdima\jsc@tocl@width \advance\@tempdima -1\zw \@dottedtocline{2}{\@tempdima}{3\zw}} \newcommand*{\l@subsubsection}{% - \@tempdima\js@tocl@width \advance\@tempdima 0\zw + \@tempdima\jsc@tocl@width \advance\@tempdima 0\zw \@dottedtocline{3}{\@tempdima}{4\zw}} \newcommand*{\l@paragraph}{% - \@tempdima\js@tocl@width \advance\@tempdima 1\zw + \@tempdima\jsc@tocl@width \advance\@tempdima 1\zw \@dottedtocline{4}{\@tempdima}{5\zw}} \newcommand*{\l@subparagraph}{% - \@tempdima\js@tocl@width \advance\@tempdima 2\zw + \@tempdima\jsc@tocl@width \advance\@tempdima 2\zw \@dottedtocline{5}{\@tempdima}{6\zw}} -% -%<*book> +% +%<*book|report> % \newcommand*{\l@subsection} {\@dottedtocline{2}{3.8em}{3.2em}} % \newcommand*{\l@subsubsection}{\@dottedtocline{3}{7.0em}{4.1em}} % \newcommand*{\l@paragraph} {\@dottedtocline{4}{10em}{5em}} % \newcommand*{\l@subparagraph} {\@dottedtocline{5}{12em}{6em}} \newcommand*{\l@section}{% - \@tempdima\js@tocl@width \advance\@tempdima -1\zw + \@tempdima\jsc@tocl@width \advance\@tempdima -1\zw \@dottedtocline{1}{\@tempdima}{3.683\zw}} \newcommand*{\l@subsection}{% - \@tempdima\js@tocl@width \advance\@tempdima 2.683\zw + \@tempdima\jsc@tocl@width \advance\@tempdima 2.683\zw \@dottedtocline{2}{\@tempdima}{3.5\zw}} \newcommand*{\l@subsubsection}{% - \@tempdima\js@tocl@width \advance\@tempdima 6.183\zw + \@tempdima\jsc@tocl@width \advance\@tempdima 6.183\zw \@dottedtocline{3}{\@tempdima}{4.5\zw}} \newcommand*{\l@paragraph}{% - \@tempdima\js@tocl@width \advance\@tempdima 10.683\zw + \@tempdima\jsc@tocl@width \advance\@tempdima 10.683\zw \@dottedtocline{4}{\@tempdima}{5.5\zw}} \newcommand*{\l@subparagraph}{% - \@tempdima\js@tocl@width \advance\@tempdima 16.183\zw + \@tempdima\jsc@tocl@width \advance\@tempdima 16.183\zw \@dottedtocline{5}{\@tempdima}{6.5\zw}} -% +% % \end{macrocode} % \end{macro} % \end{macro} @@ -4347,13 +4718,26 @@ % \end{macro} % % \begin{macro}{\@dottedtocline} +% \begin{macro}{\jsTocLine} % % \LaTeX 本体(\texttt{ltsect.dtx} 参照)での定義と同じですが, % |\@tempdima| を |\@lnumwidth| に変えています。 % +% [2018-06-23] デフォルトでは\jsTocLine のようにベースラインになります。\par +% これを変更可能にするため,|\jsTocLine| というマクロに切り出しました。 +% 例えば,仮想ボディの中央 +% {\renewcommand{\jsTocLine}{\leaders \hbox {\hss ・\hss}\hfill}\jsTocLine} +% に変更したい場合は +%\begin{verbatim} +% \renewcommand{\jsTocLine}{\leaders \hbox {\hss ・\hss}\hfill} +%\end{verbatim} +% とします。 +% % \begin{macrocode} +\def\jsTocLine{\leaders\hbox{% + $\m@th \mkern \@dotsep mu\hbox{.}\mkern \@dotsep mu$}\hfill} \def\@dottedtocline#1#2#3#4#5{\ifnum #1>\c@tocdepth \else - \vskip \z@ \@plus.2\js@mpt + \vskip \z@ \@plus.2\jsc@mpt {\leftskip #2\relax \rightskip \@tocrmarg \parfillskip -\rightskip \parindent #2\relax\@afterindenttrue \interlinepenalty\@M @@ -4361,11 +4745,11 @@ \@lnumwidth #3\relax \advance\leftskip \@lnumwidth \null\nobreak\hskip -\leftskip {#4}\nobreak - \leaders\hbox{$\m@th \mkern \@dotsep mu\hbox{.}\mkern \@dotsep - mu$}\hfill \nobreak\hb@xt@\@pnumwidth{% + \jsTocLine \nobreak\hb@xt@\@pnumwidth{% \hfil\normalfont \normalcolor #5}\par}\fi} % \end{macrocode} % \end{macro} +% \end{macro} % % \paragraph{図目次と表目次} % @@ -4375,18 +4759,18 @@ % % \begin{macrocode} \newcommand{\listoffigures}{% -%<*book> +%<*book|report> \if@twocolumn\@restonecoltrue\onecolumn \else\@restonecolfalse\fi \chapter*{\listfigurename}% \@mkboth{\listfigurename}{}% -% -%<*!book> +% +%<*!book&!report> \section*{\listfigurename}% \@mkboth{\listfigurename}{\listfigurename}% -% +% \@starttoc{lof}% -% \if@restonecol\twocolumn\fi +% \if@restonecol\twocolumn\fi } % \end{macrocode} % \end{macro} @@ -4406,18 +4790,18 @@ % % \begin{macrocode} \newcommand{\listoftables}{% -%<*book> +%<*book|report> \if@twocolumn\@restonecoltrue\onecolumn \else\@restonecolfalse\fi \chapter*{\listtablename}% \@mkboth{\listtablename}{}% -% -%<*!book> +% +%<*!book&!report> \section*{\listtablename}% \@mkboth{\listtablename}{\listtablename}% -% +% \@starttoc{lot}% -% \if@restonecol\twocolumn\fi +% \if@restonecol\twocolumn\fi } % \end{macrocode} % \end{macro} @@ -4448,8 +4832,13 @@ % % 参考文献リストを出力します。 % +% [2016-07-16] \LaTeX~2.09で使われていたフォントコマンドの警告を, +% 文献スタイル(.bst)ではよく |\bf| がいまだに用いられることが多いため, +% |thebibliography| 環境内では例外的に出さないようにしました。 +% % \begin{macrocode} \newenvironment{thebibliography}[1]{% + \global\@jsc@warnoldfontcmdexceptiontrue \global\let\presectionname\relax \global\let\postsectionname\relax % \section*{\refname}\@mkboth{\refname}{\refname}% @@ -4458,8 +4847,8 @@ \subsubsection*{\refname}\@mkboth{\refname}{\refname}% \vspace{0.5\baselineskip} % -% \chapter*{\bibname}\@mkboth{\bibname}{}% -% \addcontentsline{toc}{chapter}{\bibname}% +% \chapter*{\bibname}\@mkboth{\bibname}{}% +% \addcontentsline{toc}{chapter}{\bibname}% \list{\@biblabel{\@arabic\c@enumiv}}% {\settowidth\labelwidth{\@biblabel{#1}}% \leftmargin\labelwidth @@ -4476,7 +4865,8 @@ \sfcode`\.\@m} {\def\@noitemerr {\@latex@warning{Empty `thebibliography' environment}}% - \endlist} + \endlist + \global\@jsc@warnoldfontcmdexceptionfalse} % \end{macrocode} % \end{environment} % @@ -4523,17 +4913,17 @@ % で囲んでください。 % % \begin{macrocode} -% \def\@citex[#1]#2{% +% \def\@citex[#1]#2{\leavevmode % \let\@citea\@empty % \@cite{\@for\@citeb:=#2\do % {\@citea\def\@citea{,\inhibitglue\penalty\@m\ }% -% \edef\@citeb{\expandafter\@firstofone\@citeb}% +% \edef\@citeb{\expandafter\@firstofone\@citeb\@empty}% % \if@filesw\immediate\write\@auxout{\string\citation{\@citeb}}\fi % \@ifundefined{b@\@citeb}{\mbox{\normalfont\bfseries ?}% % \G@refundefinedtrue % \@latex@warning % {Citation `\@citeb' on page \thepage \space undefined}}% -% {\hbox{\csname b@\@citeb\endcsname}}}}{#1}} +% {\@cite@ofmt{\csname b@\@citeb\endcsname}}}}{#1}} % \def\@cite#1#2{\inhibitglue[{#1\if@tempswa ,#2\fi}]\inhibitglue} % \end{macrocode} % @@ -4567,31 +4957,31 @@ \fi \columnseprule.4pt \columnsep 2\zw \ifx\multicols\@undefined -% \twocolumn[\@makeschapterhead{\indexname}% -% \addcontentsline{toc}{chapter}{\indexname}]% -% \def\presectionname{}\def\postsectionname{}% -% \twocolumn[\section*{\indexname}]% +% \twocolumn[\@makeschapterhead{\indexname}% +% \addcontentsline{toc}{chapter}{\indexname}]% +% \def\presectionname{}\def\postsectionname{}% +% \twocolumn[\section*{\indexname}]% \else \ifdim\textwidth<\fullwidth \setlength{\evensidemargin}{\oddsidemargin} \setlength{\textwidth}{\fullwidth} \setlength{\linewidth}{\fullwidth} -% \begin{multicols}{3}[\chapter*{\indexname}% -% \addcontentsline{toc}{chapter}{\indexname}]% -% \def\presectionname{}\def\postsectionname{}% -% \begin{multicols}{3}[\section*{\indexname}]% +% \begin{multicols}{3}[\chapter*{\indexname}% +% \addcontentsline{toc}{chapter}{\indexname}]% +% \def\presectionname{}\def\postsectionname{}% +% \begin{multicols}{3}[\section*{\indexname}]% \else -% \begin{multicols}{2}[\chapter*{\indexname}% -% \addcontentsline{toc}{chapter}{\indexname}]% -% \def\presectionname{}\def\postsectionname{}% -% \begin{multicols}{2}[\section*{\indexname}]% +% \begin{multicols}{2}[\chapter*{\indexname}% +% \addcontentsline{toc}{chapter}{\indexname}]% +% \def\presectionname{}\def\postsectionname{}% +% \begin{multicols}{2}[\section*{\indexname}]% \fi \fi -% \@mkboth{\indexname}{}% -% \@mkboth{\indexname}{\indexname}% +% \@mkboth{\indexname}{}% +% \@mkboth{\indexname}{\indexname}% \plainifnotempty % \thispagestyle{plain} \parindent\z@ - \parskip\z@ \@plus .3\js@mpt\relax + \parskip\z@ \@plus .3\jsc@mpt\relax \let\item\@idxitem \raggedright \footnotesize\narrowbaselines @@ -4626,7 +5016,7 @@ % 索引で先頭文字ごとのブロックの間に入るスペースです。 % % \begin{macrocode} -\newcommand{\indexspace}{\par \vskip 10\js@mpt \@plus5\js@mpt \@minus3\js@mpt\relax} +\newcommand{\indexspace}{\par \vskip 10\jsc@mpt \@plus5\jsc@mpt \@minus3\jsc@mpt\relax} % \end{macrocode} % \end{macro} % @@ -4683,12 +5073,8 @@ % % [2016-07-11] コミュニティ版p\LaTeX の変更に追随しました(Thanks: 角藤さん)。 % -% \begin{macrocode} -\renewcommand\@makefnmark{% - \unless\ifnum\ltjgetparameter{direction}=3 - \hbox{}\hbox{\@textsuperscript{\normalfont\@thefnmark}}\hbox{}% - \else\hbox{\yoko \@textsuperscript{\normalfont\@thefnmark}}\fi} -% \end{macrocode} +% [2016-08-27 LTJ] 結果的に |\@makefnmark| の定義が +% Lua\TeX-ja本体(lltjcore.sty)中のものと全く同じになっていたので,削除します, % \end{macro} % % \begin{macro}{\thefootnote} @@ -4699,6 +5085,11 @@ % [2003-08-15] |\textasteriskcentered| ではフォントによって % 下がりすぎるので変更しました。 % +% [2016-10-08] TODO: 脚注番号が |newtxtext| や |newpxtext| の使用時に +% おかしくなってしまいます。これらのパッケージは内部で |\thefootnote| を +% 再定義していますので,気になる場合はパッケージを読み込むときに +% \texttt{defaultsups} オプションを付けてください(qa:57284, qa:57287)。 +% % \begin{macrocode} \def\thefootnote{\ifnum\c@footnote>\z@\leavevmode\lower.5ex\hbox{*}\@arabic\c@footnote\fi} % \end{macrocode} @@ -4706,7 +5097,7 @@ % 「注1」の形式にするには次のようにしてください。 % % \begin{macrocode} -% \def\thefootnote{\ifnum\c@footnote>\z@注\kern0.1\zw\@arabic\c@footnote\fi} +% \def\thefootnote{\ifnum\c@footnote>\z@ 注\kern0.1\zw\@arabic\c@footnote\fi} % \end{macrocode} % % \end{macro} @@ -4717,9 +5108,9 @@ % % \begin{macrocode} \renewcommand{\footnoterule}{% - \kern-3\js@mpt - \hrule width 0.4\columnwidth height 0.4\js@mpt - \kern 2.6\js@mpt} + \kern-3\jsc@mpt + \hrule width .4\columnwidth height 0.4\jsc@mpt + \kern 2.6\jsc@mpt} % \end{macrocode} % \end{macro} % @@ -4727,8 +5118,10 @@ % % 脚注番号は章ごとにリセットされます。 % +% [2018-03-11] |\next|などいくつかの内部命令を |\jsc@...| 付きの +% ユニークな名前にしました。 % \begin{macrocode} -%\@addtoreset{footnote}{chapter} +%\@addtoreset{footnote}{chapter} % \end{macrocode} % \end{macro} % @@ -4738,6 +5131,8 @@ % Jeremy Gibbons, \textit{\TeX\ and TUG NEWS}, % Vol.~2, No.~4 (1993), p.~9) % +% [2018-03-11] |\next|などいくつかの内部命令を |\jsc@...| 付きの +% ユニークな名前にしました。 % \begin{macrocode} \long\def\@footnotetext{% \insert\footins\bgroup @@ -4752,12 +5147,12 @@ \color@begingroup \@makefntext{% \rule\z@\footnotesep\ignorespaces}% - \futurelet\next\fo@t} -\def\fo@t{\ifcat\bgroup\noexpand\next \let\next\f@@t - \else \let\next\f@t\fi \next} -\def\f@@t{\bgroup\aftergroup\@foot\let\next} -\def\f@t#1{#1\@foot} -\def\@foot{\@finalstrut\strutbox\color@endgroup\egroup} + \futurelet\jsc@next\jsc@fo@t} +\def\jsc@fo@t{\ifcat\bgroup\noexpand\jsc@next \let\jsc@next\jsc@f@@t + \else \let\jsc@next\jsc@f@t\fi \jsc@next} +\def\jsc@f@@t{\bgroup\aftergroup\jsc@@foot\let\jsc@next} +\def\jsc@f@t#1{#1\jsc@@foot} +\def\jsc@@foot{\@finalstrut\strutbox\color@endgroup\egroup} % \end{macrocode} % \end{macro} % @@ -4810,10 +5205,13 @@ % する機能がありますが,|\item| 直後ではラベル用のボックスが段落先頭になる % ため,うまく働きませんでした。形を変えて復活させます。 % +% [2017-04-03 LTJ] 従来クラスファイルで定義していた |\@inhibitglue| は, +% Lua\TeX-jaのコアに |\ltjfakeparbegin| として正式に追加されたのでリネームします. +% % |\item| 命令の直後です。 % % \begin{macrocode} -\protected\def\@inhibitglue{\directlua{luatexja.jfmglue.create_beginpar_node()}} +\let\@inhibitglue=\ltjfakeparbegin \def\@item[#1]{% \if@noparitem \@donoparitem @@ -4856,7 +5254,7 @@ \else \clubpenalty \@clubpenalty \everypar{}% - \fi\@inhibitglue}% + \fi\ltjfakeparbegin}% \if@noitemarg \@noitemargfalse \if@nmbrlist @@ -4887,6 +5285,9 @@ % % しかし単に戻すだけでも駄目みたいなので,ここでも最後にグルーを消しておきます。 % +% [2016-12-05 LTJ] 本家[2016-11-29],lltjcore.styでの変更に追従させます. +% +% [2017-02-18 LTJ] lltjcore.sty側で戻したのを忘れていました. % \begin{macrocode} \def\@gnewline #1{% \ifvmode @@ -4901,6 +5302,24 @@ % % \LaTeX 関連のロゴを作り直します。 % +% [2016-07-14] ロゴの定義は\texttt{jslogo}パッケージに移転しました。 +% 後方互換のため,\texttt{jsclasses}ではデフォルトでこれを読み込みます。 +% \texttt{nojslogo}オプションが指定されている場合は読み込みません。 +% +% [2016-07-21 LTJ] \texttt{jsclasses} とLua\TeX-jaの更新タイミングが一致しない可能性を考慮し, +% \texttt{jslogo}パッケージが存在しない場合は旧来の定義をそのまま使うことにしました。 +% +% \begin{macrocode} +\IfFileExists{jslogo.sty}{}{\@jslogofalse}% +\if@jslogo + \RequirePackage{jslogo} + \def\小{\jslg@small} + \def\上小{\jslg@uppersmall} +\else +% \end{macrocode} +% +% 以下は\texttt{jslogo}パッケージがない場合の定義です。 +% % \begin{macro}{\小} % \begin{macro}{\上小} % @@ -5103,6 +5522,11 @@ % \end{macro} % \end{macro} % +% \texttt{jslogo}パッケージがない場合の定義はここで終わりです。 +% \begin{macrocode} +\fi +% \end{macrocode} +% % \section{初期設定} % % \paragraph{いろいろな語} @@ -5116,8 +5540,8 @@ % \begin{macrocode} \newcommand{\prepartname}{\if@english Part~\else 第\fi} \newcommand{\postpartname}{\if@english\else 部\fi} -%\newcommand{\prechaptername}{\if@english Chapter~\else 第\fi} -%\newcommand{\postchaptername}{\if@english\else 章\fi} +%\newcommand{\prechaptername}{\if@english Chapter~\else 第\fi} +%\newcommand{\postchaptername}{\if@english\else 章\fi} \newcommand{\presectionname}{}% 第 \newcommand{\postsectionname}{}% 節 % \end{macrocode} @@ -5216,12 +5640,19 @@ % \paragraph{ページ設定} % % ページ設定の初期化です。 +% |stfloats|パッケージがシステムにインストールされている場合は、このパッケージを使って +% \pLaTeX の標準時と同じようにボトムフロートの下に脚注が組まれるようにします。 % +% [2017-02-19] \pLaTeX とLua\TeX-jaの|\@makecol|が違うことを +% 考慮していませんでした。 % \begin{macrocode} -%\if@slide \pagestyle{empty} \else \pagestyle{plain} \fi +%
\if@slide \pagestyle{empty} \else \pagestyle{plain} \fi %\if@report \pagestyle{plain} \else \pagestyle{headings} \fi +%\pagestyle{plain} %\pagestyle{headings} \pagenumbering{arabic} +\fnfixbottomtrue % 2017-02-19 +\IfFileExists{stfloats.sty}{\RequirePackage{stfloats}\fnbelowfloat}{} \if@twocolumn \twocolumn \sloppy @@ -5235,7 +5666,7 @@ \renewcommand\familydefault{\sfdefault} \raggedright \ltj@setpar@global - \ltjsetxkanjiskip{0.1em}\relax + \ltjsetxkanjiskip0.1em\relax \fi % \end{macrocode} %