X-Git-Url: http://git.osdn.jp/view?a=blobdiff_plain;f=src%2Flltjext.sty;h=9e1421b130c111950c8f9b463eaa047587ad23b8;hb=b0e23554957e57c3bbafa1ac664319e4f4af249b;hp=8238e7b77d2eee87c0ac2f012f03735fe33453e0;hpb=4ab839e5f18b0f5e6d9b27a2b78cf51f4670815a;p=luatex-ja%2Fluatexja.git diff --git a/src/lltjext.sty b/src/lltjext.sty index 8238e7b..9e1421b 100644 --- a/src/lltjext.sty +++ b/src/lltjext.sty @@ -3,12 +3,9 @@ % \NeedsTeXFormat{LaTeX2e} -\ProvidesPackage{lltjext}[2017/07/17 v1.2g-ltj-6 Macros for vertical writing] +\ProvidesPackage{lltjext}[2019/09/25 v1.2k-ltj-11 Macros for vertical writing] \RequirePackage{luatexja} \newcount\ltj@ext@dir -{\catcode`\*=11 -\global\let\ltj@lltjext@orig@tabularS=\tabular* -}% \let\ltj@lltjext@orig@tabular=\tabular \let\ltj@lltjext@orig@array=\array @@ -19,16 +16,20 @@ \ltj@ext@dir=\ltjgetparameter{direction}\relax\X@tabarray} \def\tabular{\let\@halignto\@empty\X@tabular} \@namedef{tabular*}{\@ifnextchar<%> - {\@stabular}{\@stabular}} + {\p@stabular}{\p@stabular}} +{\catcode`\*=11 +\global\let\ltj@lltjext@orig@tabularS=\tabular* +}% \def\X@tabarray{\@ifnextchar<%> - {\p@tabarray}{\p@tabarray}} + {\p@tabarray}{\p@tabarray}} \def\X@tabular{\@ifnextchar<%> - {\p@tabular}{\p@tabular}} -\def\@stabular<#1>#2{% + {\p@tabular}{\p@tabular}} +\def\p@stabular<#1>#2{% \setlength\dimen@{#2}% \edef\@halignto{to\the\dimen@}\p@tabular<#1>} \def\p@tabular<#1>{\leavevmode \hbox \bgroup - \ltj@ext@dir=\ltjgetparameter{direction}$\let\@acol\@tabacol + \ltj@ext@dir=\ltjgetparameter{direction} + $\let\@acol\@tabacol \let\@classz\@tabclassz \let\@classiv\@tabclassiv \let\\\@tabularcr\p@tabarray<#1>} \def\p@tabarray<#1>{\m@th\@ifnextchar[%] @@ -59,165 +60,105 @@ \else \let\box@dir\utod\@tempcnta=\zstrutbox% utod \fi \fi + \fork@array@option<#1>[#2]\@begin@alignbox + \bgroup\box@dir\adjustbaseline \setbox\@arstrutbox\hbox{% \box@dir \vrule\@height\arraystretch\ltjgetht\@tempcnta \@depth\arraystretch\ltjgetdp\@tempcnta \@width\z@}% - \fork@array@option<#1>[#2]% \@mkpream{#3}\edef\@preamble{\ialign \noexpand\@halignto \bgroup\@arstrut \@preamble \tabskip\z@skip \cr}% \let\@startpbox\@@startpbox \let\@endpbox\@@endpbox \let\tabularnewline\\% - \@begin@alignbox\bgroup\box@dir\adjustbaseline \let\par\@empty - \let\@sharp##\let\protect\relax - \lineskip\z@skip\baselineskip\z@skip\@preamble} + \let\@sharp##% + \set@typeset@protect + \lineskip\z@skip\baselineskip\z@skip + \ifhmode \@preamerr\z@ \@@par\fi + \@preamble} \def\endarray{\crcr\egroup\egroup\@end@alignbox} \def\endtabular{\endarray$\egroup} \expandafter \let \csname endtabular*\endcsname = \endtabular -% コミュニティ版では、アスキー版で不自然だった表組(array環境およびtabular環境)と -% 周囲の本文との揃え位置を修正し、以下のように設計しました。 -% \begin{itemize} -% \item 周囲の組方向が横組かつ組方向が||, ||指定の場合 -% \begin{itemize} -% \item |[t]|指定のとき\\一行目のベースラインが周囲のそれと一致(罫線の場合は和文ベースラインの位置) -% \item |[c]|指定のとき\\表組の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下) -% \item |[b]|指定のとき\\最終行のベースラインが周囲のそれと一致(罫線の場合は和文ベースラインの位置) -% \end{itemize} -% \item 周囲の組方向が横組かつ組方向が||指定の場合 -% \begin{itemize} -% \item |[t]|指定のとき\\表組の上端が周囲の和文ベースラインと一致 -% \item |[c]|指定のとき\\表組の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下) -% \item |[b]|指定のとき\\表組の下端が周囲の和文ベースラインと一致 -% \end{itemize} -% \item 周囲の組方向が縦組かつ組方向が||指定の場合 -% \begin{itemize} -% \item |[t]|指定のとき\\表組の上端が周囲の和文ベースラインと一致 -% \item |[c]|指定のとき\\表組の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下) -% \item |[b]|指定のとき\\表組の下端が周囲の和文ベースラインと一致 -% \end{itemize} -% \item 周囲の組方向が縦組かつ組方向が||指定の場合 -% \begin{itemize} -% \item |[t]|指定のとき\\一行目のベースラインが周囲のそれと一致(罫線の場合は和文ベースラインの位置) -% \item |[c]|指定のとき\\表組の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下) -% \item |[b]|指定のとき\\最終行のベースラインが周囲のそれと一致(罫線の場合は和文ベースラインの位置) -% \end{itemize} -% \item 周囲の組方向が縦組かつ組方向が||指定の場合 -% \begin{itemize} -% \item |[t]|指定のとき\\一行目の欧文ベースラインが周囲のそれと一致 -% \item |[c]|指定のとき\\表組の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下) -% \item |[b]|指定のとき\\最終行の欧文ベースラインが周囲のそれと一致 -% \end{itemize} -\def\fork@array@option<#1>[#2]{% -\ifnum\ltjgetparameter{direction}=4 % yoko - \ifx\box@dir\yoko - \if #2t\relax - \let\@begin@alignbox\vtop - \let\@end@alignbox\relax - \else\if #2b\relax - \let\@begin@alignbox\vbox - \let\@end@alignbox\relax - \else - \let\@begin@alignbox\vcenter - \let\@end@alignbox\relax - \fi\fi +% ↓中身\周囲→ yoko tate utod dtou +% yoko A* B* B B +% tate B* A* D C +% utod B D* A C +% dtou B C C A +% A: 周囲と中身の組方向が一致.そのまま \vtop/\vcenter/\vbox +% B: 周囲と中身が90度ずれ.上端/下端がベースラインに揃うように +% C: 周囲と中身が180度ずれ.\vtop, \vbox 入れ替え +% D: 欧文ベースライン同士を揃えるようにする + +\def\fork@array@option@@A#1{% + \let\@end@alignbox\relax + \if #1t\relax \let\@begin@alignbox\vtop + \else\if #1b\relax\let\@begin@alignbox\vbox + \else \let\@begin@alignbox\vcenter + \fi\fi} +\def\fork@array@option@@B#1{% + \if #1t\relax + \def\@begin@alignbox{\vtop\bgroup\kern\z@\vbox}% + \let\@end@alignbox\egroup + \else\if #1b\relax + \def\@begin@alignbox{\vbox\bgroup\vbox}% + \def\@end@alignbox{\kern\z@\egroup}% \else - \if #2t\relax - \def\@begin@alignbox{\vtop\bgroup\kern\z@\vbox}% - \let\@end@alignbox\egroup - \else\if #2b\relax - \def\@begin@alignbox{\vbox\bgroup\vbox}% - \def\@end@alignbox{\kern\z@\egroup}% - \else - \let\@begin@alignbox\vcenter - \let\@end@alignbox\relax - \fi\fi + \let\@begin@alignbox\vcenter + \let\@end@alignbox\relax + \fi\fi} +\def\fork@array@option@@C#1{% + \let\@end@alignbox\relax + \if #1t\relax \let\@begin@alignbox\vbox + \else\if #1b\relax\let\@begin@alignbox\vtop + \else \let\@begin@alignbox\vcenter + \fi\fi} +\def\fork@array@option<#1>[#2]{% +\ifnum\ltj@ext@dir=4 % yoko + \ifx\box@dir\yoko \fork@array@option@@A{#2}% + \else \fork@array@option@@B{#2}% \fi -\else\ifnum\ltjgetparameter{direction}=1 % dtou - \ifx\box@dir\yoko - \if #2t\relax - \def\@begin@alignbox{\vtop\bgroup\kern\z@\vbox}% - \let\@end@alignbox\egroup - \else\if #2b\relax - \def\@begin@alignbox{\vbox\bgroup\vbox}% - \def\@end@alignbox{\kern\z@\egroup}% - \else - \let\@begin@alignbox\vcenter - \let\@end@alignbox\relax - \fi\fi - \else\ifx\box@dir\dtou - \if #2t\relax - \let\@begin@alignbox\vtop - \let\@end@alignbox\relax - \else\if #2b\relax - \let\@begin@alignbox\vbox - \let\@end@alignbox\relax - \else - \let\@begin@alignbox\vcenter - \let\@end@alignbox\relax - \fi\fi - \else % 180 度回転→vtop, vbox を入れ替える - \if #2t\relax - \let\@begin@alignbox\vbox %%% !!! - \let\@end@alignbox\relax - \else\if #2b\relax - \let\@begin@alignbox\vtop %%% !!! - \let\@end@alignbox\relax - \else - \let\@begin@alignbox\vcenter - \let\@end@alignbox\relax - \fi\fi +\else\ifnum\ltj@ext@dir=1 % dtou + \ifx\box@dir\yoko \fork@array@option@@B{#2}% + \else\ifx\box@dir\dtou \fork@array@option@@A{#2}% + \else \fork@array@option@@C{#2}% \fi\fi -\else % tate, utod - \ifx\box@dir\yoko +\else\ifnum\ltj@ext@dir=3 % tate + \ifx\box@dir\yoko \fork@array@option@@B{#2}% + \else\ifx\box@dir\tate \fork@array@option@@A{#2}% + \else\ifx\box@dir\dtou \fork@array@option@@C{#2}% + \else \if #2t\relax - \def\@begin@alignbox{\vtop\bgroup\kern\z@\vbox}% - \let\@end@alignbox\egroup + \def\@begin@alignbox{\lower\dimexpr + \ltjgetparameter{talbaselineshift}-\ltjgetparameter{yalbaselineshift}\vtop} + \let\@end@alignbox\relax \else\if #2b\relax - \def\@begin@alignbox{\vbox\bgroup\vbox}% - \def\@end@alignbox{\kern\z@\egroup}% + \def\@begin@alignbox{\lower\dimexpr + \ltjgetparameter{talbaselineshift}-\ltjgetparameter{yalbaselineshift}\vbox} + \let\@end@alignbox\relax \else \let\@begin@alignbox\vcenter \let\@end@alignbox\relax \fi\fi - \else\ifx\box@dir\dtou % 180 度回転→vtop, vbox を入れ替える + \fi\fi\fi +\else % utod + \ifx\box@dir\yoko \fork@array@option@@B{#2}% + \else\ifx\box@dir\utod \fork@array@option@@A{#2}% + \else\ifx\box@dir\dtou \fork@array@option@@C{#2}% + \else \if #2t\relax - \let\@begin@alignbox\vbox %%% !!! + \def\@begin@alignbox{\lower\dimexpr + \ltjgetparameter{yalbaselineshift}-\ltjgetparameter{talbaselineshift}\vtop} \let\@end@alignbox\relax \else\if #2b\relax - \let\@begin@alignbox\vtop %%% !!! + \def\@begin@alignbox{\lower\dimexpr + \ltjgetparameter{yalbaselineshift}-\ltjgetparameter{talbaselineshift}\vbox} \let\@end@alignbox\relax \else \let\@begin@alignbox\vcenter \let\@end@alignbox\relax \fi\fi - \else\ifx\box@dir\tate - \if #2t\relax - \let\@begin@alignbox\vtop - \let\@end@alignbox\relax - \else\if #2b\relax - \let\@begin@alignbox\vbox - \let\@end@alignbox\relax - \else - \let\@begin@alignbox\vcenter - \let\@end@alignbox\relax - \fi\fi - \else % utod - \if #2t\relax - \def\@begin@alignbox{\lower\dimexpr - \ltjgetparameter{talbaselineshift}-\ltjgetparameter{yalbaselineshift}\vtop} - \let\@end@alignbox\relax - \else\if #2b\relax - \def\@begin@alignbox{\lower\dimexpr - \ltjgetparameter{talbaselineshift}-\ltjgetparameter{yalbaselineshift}\vbox} - \let\@end@alignbox\relax - \else - \let\@begin@alignbox\vcenter - \let\@end@alignbox\relax - \fi\fi \fi\fi\fi -\fi\fi% -} +\fi\fi\fi} %%% caption \newbox\@floatbox @@ -255,18 +196,18 @@ }\hrule width\floatwidth height\floatruletick depth\z@}} \def\DeclareLayoutCaption#1<#2>(#3)[#4#5]{% \expandafter - \ifx\csname #1@layoutcaption\endcsname\relax \else + \ifx\csname #1@layoutc@ption\endcsname\relax \else \@latex@info{Redeclaring capiton layout setting of '#1'}% \fi \expandafter - \gdef\csname #1@layoutcaption\endcsname{% + \gdef\csname #1@layoutc@ption\endcsname{% \if Z\caption@dir\def\caption@dir{#2}\fi \ifdim\captionwidth=\z@ \captionwidth=#3\relax\fi \if Z\caption@posa\def\caption@posa{#4}\fi \if Z\caption@posb\def\caption@posb{#5}\fi}} \@onlypreamble\DeclareLayoutCaption -\DeclareLayoutCaption{figure}(.8\linewidth)[cd] -\DeclareLayoutCaption{table}(.8\linewidth)[cu] +\DeclareLayoutCaption{figure}(.8\linewidth)[cd] +\DeclareLayoutCaption{table}(.8\linewidth)[cu] \def\layoutcaption{\def\caption@dir{Z}\captionwidth\z@ \def\caption@posa{Z}\def\caption@posb{Z}% \@ifnextchar<\X@layoutcaption{% @@ -279,12 +220,21 @@ \@ifnextchar[{\@iilayoutcaption}{\relax}} \def\@iilayoutcaption[#1#2]{% \def\caption@posa{#1}\def\caption@posb{#2}} -\def\pcaption{\refstepcounter\@captype \@dblarg{\@pcaption\@captype}} +\def\pcaption{% + \ifx\@captype\@undefined + \@latex@error{\noexpand\pcaption outside float}\@ehd + \expandafter\@gobble + \else + \refstepcounter\@captype + \expandafter\@firstofone + \fi + {\@dblarg{\@pcaption\@captype}}% +} \long\def\@pcaption#1[#2]#3{% \addcontentsline{\csname ext@#1\endcsname}{#1}{% \protect\numberline{\csname the#1\endcsname}{\ignorespaces#2}}% \ifvoid\@floatbox - \latex@error{Use with `\protect\layoutfloat'.}\@eha + \@latex@error{Use \noexpand\pcaption with `\protect\layoutfloat'}\@eha \fi \make@pcaptionbox{#3}% \@pboxswfalse @@ -292,22 +242,23 @@ \if l\caption@posb\box\@captionbox\kern\captionfloatsep\fi \if t\caption@posa\vtop \else\if b\caption@posa\vbox - \else\ifmmode\vcenter \else\@pboxswtrue $\vcenter \fi\fi\fi + \else\@pboxswtrue $\vcenter \fi\fi {\if u\caption@posb\box\@captionbox\kern\captionfloatsep\fi \unvbox\@floatbox \if d\caption@posb\kern\captionfloatsep\box\@captionbox\fi}% + \if@pboxsw \m@th$\fi \if r\caption@posb\kern\captionfloatsep\box\@captionbox\fi - \if@pboxsw \m@th$\fi \if r\float@pos\else\hss\fi}}% + \if r\float@pos\else\hss\fi}}% \par\vskip.25\baselineskip \box\@tempboxa} \def\make@pcaptionbox#1{% \expandafter - \ifx\csname\@captype @layoutcaption\endcsname\relax + \ifx\csname\@captype @layoutc@ption\endcsname\relax \@latex@warning{Default caption layout of `\@captype' unknown.}% \def\caption@dir{Z}\captionwidth\z@ \def\caption@posa{Z}\def\caption@posb{Z}% \else - \csname \@captype @layoutcaption\endcsname + \csname \@captype @layoutc@ption\endcsname \fi \@tempswafalse % \@tempswa: 基本組の組方向とキャプションの組方向が直交するか? @@ -325,7 +276,8 @@ \setbox0\hbox{\hbox{\captiondir \captionfontsetup\parindent\z@\inhibitglue \csname fnum@\@captype\endcsname  #1}}%" - \if@tempswa\@tempdima\ltjgetht0\relax\else\@tempdima\ltjgetwd0\relax\fi + \if@tempswa\@tempdima\ltjgetht0 \advance\@tempdima\ltjgetdp0 + \else\@tempdima\ltjgetwd0 \fi \ifdim\@tempdima>\captionwidth \@tempdima\captionwidth \fi \@pboxswfalse \setbox0\hbox{% @@ -428,45 +380,53 @@ \let\hss\vss\let\unhbox\unvbox \csname bm@#4\endcsname}\@end@parbox \@end@tempboxa} -% コミュニティ版では、アスキー版で不自然だった|\parbox|の箱と -% 周囲の本文との揃え位置を修正し、以下のように設計しました。 -% \begin{itemize} -% \item 周囲の組方向が横組かつ組方向が||, ||指定の場合 -% \begin{itemize} -% \item |[t]|指定のとき\\一行目のベースラインが周囲のそれと一致 -% \item |[c]|指定のとき\\箱の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下) -% \item |[b]|指定のとき\\最終行のベースラインが周囲のそれと一致 -% \end{itemize} -% \item 周囲の組方向が横組かつ組方向が||指定の場合 -% \begin{itemize} -% \item |[t]|指定のとき\\箱の上端が周囲の和文文字の高さと一致 -% \item |[c]|指定のとき\\箱の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下) -% \item |[b]|指定のとき\\箱の下端が周囲の和文文字の深さと一致 -% \end{itemize} -% \item 周囲の組方向が縦組かつ組方向が||指定の場合 -% \begin{itemize} -% \item |[t]|指定のとき\\箱の上端が周囲の和文文字の高さと一致 -% \item |[c]|指定のとき\\箱の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下) -% \item |[b]|指定のとき\\箱の下端が周囲の和文文字の深さと一致 -% \end{itemize} -% \item 周囲の組方向が縦組かつ組方向が||指定の場合 -% \begin{itemize} -% \item |[t]|指定のとき\\一行目のベースラインが周囲のそれと一致 -% \item |[c]|指定のとき\\箱の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下) -% \item |[b]|指定のとき\\最終行のベースラインが周囲のそれと一致 -% \end{itemize} -% \item 周囲の組方向が縦組かつ組方向が||指定の場合 -% [TODO] 未定! -%^^A \begin{itemize} -%^^A \item |[t]|指定のとき\\箱の上端が周囲の和文ベースラインと一致 -%^^A \item |[c]|指定のとき\\箱の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下) -%^^A \item |[b]|指定のとき\\箱の下端が周囲の和文ベースラインと一致 -%^^A \end{itemize} -% \end{itemize} + + +% ↓中身\周囲→ yoko tate utod dtou +% yoko A* B* B B +% tate B* A* D C +% utod B D* A C +% dtou B C C A +% A: 周囲と中身の組方向が一致.そのまま \vtop/\vcenter/\vbox +% B: 周囲と中身が90度ずれ.上端が和文の高さ or 下端が和文の深さに揃うように +% C: 周囲と中身が180度ずれ.(コードは B のものを流用) +% D: 上端が和文の高さ or 下端が和文の深さに揃うように(コードは B のものを流用) + +\def\fork@parbox@option@@A#1{% + \let\@end@parbox\relax + \if #1t\relax \let\@begin@parbox\vtop + \else\if #1b\relax\let\@begin@parbox\vbox + \else + \ifmmode + \let\@begin@parbox\vcenter\let\@end@parbox\relax + \else + \def\@begin@parbox{\null$\vcenter}% + \def\@end@parbox{\m@th$\null}% + \fi + \fi\fi} +\def\lltjext@getjablshift{% + \ifnum\ltj@ext@dir=3 \ltjgetparameter{tjabaselineshift}\else + \ltjgetparameter{yjabaselineshift}\fi} +\def\fork@parbox@option@@B#1{% + \if #1t\relax + \def\@begin@parbox{\raise\dimexpr\cht-\lltjext@getjablshift\vtop\bgroup\kern\z@\vbox}% + \let\@end@parbox\egroup + \else\if #1b\relax + \def\@begin@parbox{\lower\dimexpr\cdp+\lltjext@getjablshift\vbox\bgroup\vbox}% + \def\@end@parbox{\kern\z@\egroup}% + \else + \ifmmode + \let\@begin@parbox\vcenter\let\@end@parbox\relax + \else + \def\@begin@parbox{\null$\vcenter}% + \def\@end@parbox{\m@th$\null}% + \fi + \fi\fi} +\let\fork@parbox@option@@C=\fork@parbox@option@@B \def\fork@parbox@option<#1>[#2]{% - \let\box@dir\relax + \let\box@dir\relax \ltj@ext@dir=\ltjgetparameter{direction}\relax \if #1z\relax - \ifnum\ltjgetparameter{direction}=3\relax + \ifnum\ltj@ext@dir=3\relax \let\box@dir\utod \fi \else @@ -477,156 +437,35 @@ \fi\fi\fi\fi \fi \ifx\box@dir\relax - \ifcase\ltjgetparameter{direction}\relax + \ifcase\ltj@ext@dir \or \let\box@dir\dtou \or\or\let\box@dir\tate \or \let\box@dir\yoko \else \let\box@dir\utod \fi \fi -\ifnum\ltjgetparameter{direction}=4 % yoko - \ifx\box@dir\yoko - \if #2t\relax - \let\@begin@parbox\vtop - \let\@end@parbox\relax - \else\if #2b\relax - \let\@begin@parbox\vbox - \let\@end@parbox\relax - \else - \ifmmode - \let\@begin@parbox\vcenter\let\@end@parbox\relax - \else - \def\@begin@parbox{\null$\vcenter}% - \def\@end@parbox{\m@th$\null}% - \fi - \fi\fi - \else - \if #2t\relax - \def\@begin@parbox{\raise\cht\vtop\bgroup\kern\z@\vbox}% - \let\@end@parbox\egroup - \else\if #2b\relax - \def\@begin@parbox{\lower\cdp\vbox\bgroup\vbox}% - \def\@end@parbox{\kern\z@\egroup}% - \else - \ifmmode - \let\@begin@parbox\vcenter\let\@end@parbox\relax - \else - \def\@begin@parbox{\null$\vcenter}% - \def\@end@parbox{\m@th$\null}% - \fi - \fi\fi +\ifnum\ltj@ext@dir=4 % yoko + \ifx\box@dir\yoko \fork@parbox@option@@A{#2}% + \else \fork@parbox@option@@B{#2}% \fi -\else\ifnum\ltjgetparameter{direction}=1 % dtou - \ifx\box@dir\yoko - \if #2t\relax - \def\@begin@parbox{\raise\cht\vtop\bgroup\kern\z@\vbox}% - \let\@end@parbox\egroup - \else\if #2b\relax - \def\@begin@parbox{\lower\cdp\vbox\bgroup\vbox}% - \def\@end@parbox{\kern\z@\egroup}% - \else - \ifmmode - \let\@begin@parbox\vcenter\let\@end@parbox\relax - \else - \def\@begin@parbox{\null$\vcenter}% - \def\@end@parbox{\m@th$\null}% - \fi - \fi\fi - \else\ifx\box@dir\dtou - \if #2t\relax - \let\@begin@parbox\vtop - \let\@end@parbox\relax - \else\if #2b\relax - \let\@begin@parbox\vbox - \let\@end@parbox\relax - \else - \ifmmode - \let\@begin@parbox\vcenter\let\@end@parbox\relax - \else - \def\@begin@parbox{\null$\vcenter}% - \def\@end@parbox{\m@th$\null}% - \fi - \fi\fi - \else % 180 度回転→vtop, vbox を入れ替える - \if #2t\relax - \let\@begin@parbox\vbox %%% !!! - \let\@end@parbox\relax - \else\if #2b\relax - \let\@begin@parbox\vtop %%% !!! - \let\@end@parbox\relax - \else - \ifmmode - \let\@begin@parbox\vcenter\let\@end@parbox\relax - \else - \def\@begin@parbox{\null$\vcenter}% - \def\@end@parbox{\m@th$\null}% - \fi - \fi\fi +\else\ifnum\ltj@ext@dir=1 % dtou + \ifx\box@dir\yoko \fork@parbox@option@@B{#2}% + \else\ifx\box@dir\dtou \fork@parbox@option@@A{#2}% + \else \fork@parbox@option@@C{#2}% \fi\fi -\else % tate, utod - \ifx\box@dir\yoko - \if #2t\relax - \def\@begin@parbox{\raise\cht\vtop\bgroup\kern\z@\vbox}% - \let\@end@parbox\egroup - \else\if #2b\relax - \def\@begin@parbox{\lower\cdp\vbox\bgroup\vbox}% - \def\@end@parbox{\kern\z@\egroup}% - \else - \ifmmode - \let\@begin@parbox\vcenter\let\@end@parbox\relax - \else - \def\@begin@parbox{\null$\vcenter}% - \def\@end@parbox{\m@th$\null}% - \fi - \fi\fi - \else\ifx\box@dir\tate - \if #2t\relax - \let\@begin@parbox\vtop - \let\@end@parbox\relax - \else\if #2b\relax - \let\@begin@parbox\vbox - \let\@end@parbox\relax - \else - \ifmmode - \let\@begin@parbox\vcenter\let\@end@parbox\relax - \else - \def\@begin@parbox{\null$\vcenter}% - \def\@end@parbox{\m@th$\null}% - \fi - \fi\fi - \else\ifx\box@dir\dtou % 180 度回転→vtop, vbox を入れ替える - \if #2t\relax - \let\@begin@parbox\vbox %%% !!! - \let\@end@parbox\relax - \else\if #2b\relax - \let\@begin@parbox\vtop %%% !!! - \let\@end@parbox\relax - \else - \ifmmode - \let\@begin@parbox\vcenter\let\@end@parbox\relax - \else - \def\@begin@parbox{\null$\vcenter}% - \def\@end@parbox{\m@th$\null}% - \fi - \fi\fi - \else % \utod - \if #2t\relax - \def\@begin@parbox{\raise\cht\vtop\bgroup\kern\z@\vtop}% - \let\@end@parbox\egroup - \else\if #2b\relax - \def\@begin@parbox{\lower\cdp\vbox\bgroup\kern\z@\vbox}% - \let\@end@parbox\egroup - \else - \ifmmode - \let\@begin@parbox\vcenter\let\@end@parbox\relax - \else - \def\@begin@parbox{\null$\vcenter}% - \def\@end@parbox{\m@th$\null}% - \fi - \fi\fi +\else\ifnum\ltj@ext@dir=3 % tate + \ifx\box@dir\yoko \fork@parbox@option@@B{#2}% + \else\ifx\box@dir\tate \fork@parbox@option@@A{#2}% + \else\ifx\box@dir\dtou \fork@parbox@option@@C{#2}% + \else \fork@parbox@option@@B{#2}% D \fi\fi\fi -\fi\fi% -} +\else % utod + \ifx\box@dir\yoko \fork@parbox@option@@B{#2}% + \else\ifx\box@dir\utod \fork@parbox@option@@A{#2}% + \else\ifx\box@dir\dtou \fork@parbox@option@@C{#2}% + \else \fork@parbox@option@@B{#2}% D + \fi\fi\fi +\fi\fi\fi} %%% pbox \DeclareRobustCommand\pbox{\leavevmode\@ifnextchar<{\X@makePbox}{\X@makePbox}} @@ -792,9 +631,9 @@ %%% bou %%% \def\boutenchar{\char\euc"A1A2}%" -\def\bou#1{\ifvmode\leavevmode\fi\@bou#1\end} +\DeclareRobustCommand\bou[1]{\ifvmode\leavevmode\fi\@bou#1\end} \def\@bou#1{% - \ifx#1\end \let\next=\relax + \ifx#1\end \let\ltj@@next=\relax \else \ifnum\ltjgetparameter{direction}=3\relax \hbox to\z@{\vbox to\z@{\boxmaxdepth\maxdimen @@ -805,11 +644,11 @@ \vss\moveleft-0.2\zw\hbox{\boutenchar}\nointerlineskip \hbox{\char\euc"A1A1}}\hss}\nobreak#1\relax \fi - \let\next=\@bou - \fi\next} + \let\ltj@@next=\@bou + \fi\ltj@@next} %%% kasen -\def\kasen#1{% +\DeclareRobustCommand\kasen[1]{% \ifnum\ltjgetparameter{direction}=3\relax \setbox\z@\hbox{#1}\leavevmode\raise.7\zw \hbox to\z@{\vrule\@width\wd\z@ \@depth\z@ \@height.4\p@\hss}% @@ -830,13 +669,29 @@ \hbox\bgroup\ltj@ext@dir=\ltjgetparameter{direction}}{}{} \pretocmd{\array}% {\ltj@ext@dir=\ltjgetparameter{direction}\relax}{}{} + \expandafter\let\csname tabular*\endcsname=\ltj@lltjext@orig@tabularS + \patchcmd{\p@stabular}{\p@tabular}{\@tabular}{}{} + \@ifpackagelater{array}{2018/09/13} + {\expandafter\@firstoftwo} + {\expandafter\@secondoftwo} + {% = for 2018/09/13 v2.4i or newer \def\@startpbox##1{\bgroup - \box@dir\adjustbaseline%%% これを追加 - \setlength\hsize{##1}\@arrayparboxrestore - \everypar{% - \vrule \@height \ltjgetht\@arstrutbox \@width \z@ - \everypar{}}% - } + \color@begingroup + \box@dir\adjustbaseline%%% これを追加 + \setlength\hsize{##1}\@arrayparboxrestore + \everypar{% + \vrule \@height \ltjgetht\@arstrutbox \@width \z@ + \everypar{}}% + }% + }{ % = for 2018/04/30 v2.4h or older + \def\@startpbox##1{\bgroup + \box@dir\adjustbaseline%%% これを追加 + \setlength\hsize{##1}\@arrayparboxrestore + \everypar{% + \vrule \@height \ltjgetht\@arstrutbox \@width \z@ + \everypar{}}% + }% + }% \def\@tabarray{\@ifnextchar<\p@tabarray{\p@tabarray}} \def\p@array<##1>[##2]##3{% \let\box@dir\relax @@ -885,12 +740,10 @@ } \@ifpackageloaded{array}{% - \expandafter\let\csname tabular*\endcsname=\ltj@lltjext@orig@tabularS \let\tabular=\ltj@lltjext@orig@tabular \let\array=\ltj@lltjext@orig@array \ltj@lltjext@patch@array }{% - \let\ltj@lltjext@orig@tabularS\relax \let\ltj@lltjext@orig@tabular\relax \let\ltj@lltjext@orig@array\relax \RequirePackage{filehook,etoolbox} @@ -899,7 +752,7 @@ %%%%%%%%%%%%%%%% LuaTeX-ja original -\define@key[ltj]{japaram}{autouprightnum}{% %COUNT - \ltj@@set@stack{AURN}{0}{10000}\z@#1 } +%%\define@key[ltj]{japaram}{autouprightnum}{% %COUNT +%% \ltj@@set@stack{AURN}{0}{10000}\z@#1 } \endinput