OSDN Git Service

sync with platex/f8d5166
[luatex-ja/luatexja.git] / src / lltjext.sty
1 %
2 % lltjext.sty: derived from plext.sty in pLaTeX.
3 %
4
5 \NeedsTeXFormat{LaTeX2e}
6 \ProvidesPackage{lltjext}[2017/04/06 v1.2f-ltj-5 Macros for vertical writing]
7 \RequirePackage{luatexja}
8
9 {\catcode`\*=11
10 \global\let\ltj@lltjext@orig@tabularS=\tabular*
11 }%
12 \let\ltj@lltjext@orig@tabular=\tabular
13 \let\ltj@lltjext@orig@array=\array
14
15 %%% array and tabular
16 \def\array{\let\@acol\@arrayacol \let\@classz\@arrayclassz
17  \let\@classiv\@arrayclassiv
18  \let\\\@arraycr\let\@halignto\@empty\X@tabarray}
19 \def\tabular{\let\@halignto\@empty\X@tabular}
20 \@namedef{tabular*}{\@ifnextchar<%>
21    {\@stabular}{\@stabular<Z>}}
22 \def\X@tabarray{\@ifnextchar<%>
23    {\p@tabarray}{\p@tabarray<Z>}}
24 \def\X@tabular{\@ifnextchar<%>
25    {\p@tabular}{\p@tabular<Z>}}
26 \def\@stabular<#1>#2{%
27    \setlength\dimen@{#2}%
28    \edef\@halignto{to\the\dimen@}\p@tabular<#1>}
29 \def\p@tabular<#1>{\leavevmode \hbox \bgroup 
30    \count@=\ltjgetparameter{direction}$\let\@acol\@tabacol
31    \let\@classz\@tabclassz
32    \let\@classiv\@tabclassiv \let\\\@tabularcr\p@tabarray<#1>}
33 \def\p@tabarray<#1>{\m@th\@ifnextchar[%]
34    {\p@array<#1>}{\p@array<#1>[c]}}
35
36 \def\p@array<#1>[#2]#3{%
37   \let\box@dir\relax
38   \if #1z\relax
39     \ifnum\count@=3\relax
40       \let\box@dir\utod\@tempcnta=\zstrutbox
41     \fi
42   \else
43     \if #1y\relax
44        \let\box@dir\yoko\@tempcnta=\ystrutbox
45     \else\if #1t\relax
46        \let\box@dir\tate\@tempcnta=\tstrutbox
47     \else\if #1d\relax
48        \let\box@dir\dtou\@tempcnta=\dstrutbox
49     \else\if #1u\relax
50        \let\box@dir\utod\@tempcnta=\zstrutbox
51     \fi\fi\fi\fi
52   \fi
53   \ifx\box@dir\relax
54     \ifcase\count@
55        \or   \let\box@dir\dtou\@tempcnta=\dstrutbox% dtou
56        \or\or\let\box@dir\tate\@tempcnta=\tstrutbox% tate
57        \or   \let\box@dir\yoko\@tempcnta=\ystrutbox% yoko
58        \else \let\box@dir\utod\@tempcnta=\zstrutbox% utod
59     \fi
60   \fi
61   \setbox\@arstrutbox\hbox{%
62     \box@dir
63     \vrule\@height\arraystretch\ltjgetht\@tempcnta
64           \@depth\arraystretch\ltjgetdp\@tempcnta \@width\z@}%
65   \fork@array@option<#1>[#2]%
66   \@mkpream{#3}\edef\@preamble{\ialign \noexpand\@halignto
67   \bgroup\@arstrut \@preamble \tabskip\z@skip \cr}%
68    \let\tabularnewline\\%
69   \@begin@alignbox\bgroup\box@dir\adjustbaseline
70     \let\par\@empty
71     \let\@sharp##\let\protect\relax
72     \lineskip\z@skip\baselineskip\z@skip\@preamble}
73 \def\endarray{\crcr\egroup\egroup\@end@alignbox}
74 \def\endtabular{\endarray$\egroup}
75 \expandafter \let \csname endtabular*\endcsname = \endtabular
76 % コミュニティ版では、アスキー版で不自然だった表組(array環境およびtabular環境)と
77 % 周囲の本文との揃え位置を修正し、以下のように設計しました。
78 % \begin{itemize}
79 % \item 周囲の組方向が横組かつ組方向が|<y>|, |<z>|指定の場合
80 % \begin{itemize}
81 %   \item |[t]|指定のとき\\一行目のベースラインが周囲のそれと一致(罫線の場合は和文ベースラインの位置)
82 %   \item |[c]|指定のとき\\表組の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下)
83 %   \item |[b]|指定のとき\\最終行のベースラインが周囲のそれと一致(罫線の場合は和文ベースラインの位置)
84 % \end{itemize}
85 % \item 周囲の組方向が横組かつ組方向が|<t>|指定の場合
86 % \begin{itemize}
87 %   \item |[t]|指定のとき\\表組の上端が周囲の和文ベースラインと一致
88 %   \item |[c]|指定のとき\\表組の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下)
89 %   \item |[b]|指定のとき\\表組の下端が周囲の和文ベースラインと一致
90 % \end{itemize}
91 % \item 周囲の組方向が縦組かつ組方向が|<y>|指定の場合
92 % \begin{itemize}
93 %   \item |[t]|指定のとき\\表組の上端が周囲の和文ベースラインと一致
94 %   \item |[c]|指定のとき\\表組の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下)
95 %   \item |[b]|指定のとき\\表組の下端が周囲の和文ベースラインと一致
96 % \end{itemize}
97 % \item 周囲の組方向が縦組かつ組方向が|<t>|指定の場合
98 % \begin{itemize}
99 %   \item |[t]|指定のとき\\一行目のベースラインが周囲のそれと一致(罫線の場合は和文ベースラインの位置)
100 %   \item |[c]|指定のとき\\表組の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下)
101 %   \item |[b]|指定のとき\\最終行のベースラインが周囲のそれと一致(罫線の場合は和文ベースラインの位置)
102 % \end{itemize}
103 % \item 周囲の組方向が縦組かつ組方向が|<z>|指定の場合
104 %  [TODO] 未定!
105 %^^A \begin{itemize}
106 %^^A   \item |[t]|指定のとき\\表組の上端が周囲の和文ベースラインと一致
107 %^^A   \item |[c]|指定のとき\\表組の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下)
108 %^^A   \item |[b]|指定のとき\\表組の下端が周囲の和文ベースラインと一致
109 %^^A \end{itemize}
110 \def\fork@array@option<#1>[#2]{%
111 \ifnum\ltjgetparameter{direction}=4 % yoko
112   \ifx\box@dir\yoko
113     \if #2t\relax
114        \let\@begin@alignbox\vtop
115        \let\@end@alignbox\relax
116     \else\if #2b\relax
117        \let\@begin@alignbox\vbox
118        \let\@end@alignbox\relax
119     \else
120        \let\@begin@alignbox\vcenter
121        \let\@end@alignbox\relax
122     \fi\fi
123   \else
124     \if #2t\relax
125        \def\@begin@alignbox{\vtop\bgroup\kern\z@\vbox}%
126        \let\@end@alignbox\egroup
127     \else\if #2b\relax
128        \def\@begin@alignbox{\vbox\bgroup\vbox}%
129        \def\@end@alignbox{\kern\z@\egroup}%
130     \else
131        \let\@begin@alignbox\vcenter
132        \let\@end@alignbox\relax
133     \fi\fi
134   \fi
135 \else\ifnum\ltjgetparameter{direction}=1 % dtou
136   \ifx\box@dir\yoko
137     \if #2t\relax
138        \def\@begin@alignbox{\vtop\bgroup\kern\z@\vbox}%
139        \let\@end@alignbox\egroup
140     \else\if #2b\relax
141        \def\@begin@alignbox{\vbox\bgroup\vbox}%
142        \def\@end@alignbox{\kern\z@\egroup}%
143     \else
144       \let\@begin@alignbox\vcenter
145         \let\@end@alignbox\relax
146     \fi\fi
147   \else\ifx\box@dir\dtou
148     \if #2t\relax
149        \let\@begin@alignbox\vtop
150        \let\@end@alignbox\relax
151     \else\if #2b\relax
152        \let\@begin@alignbox\vbox
153        \let\@end@alignbox\relax
154     \else
155        \let\@begin@alignbox\vcenter
156        \let\@end@alignbox\relax
157     \fi\fi
158   \else % 180 度回転→vtop, vbox を入れ替える
159     \if #2t\relax
160        \let\@begin@alignbox\vbox %%% !!!
161        \let\@end@alignbox\relax
162     \else\if #2b\relax
163        \let\@begin@alignbox\vtop %%% !!!
164        \let\@end@alignbox\relax
165     \else
166        \let\@begin@alignbox\vcenter
167        \let\@end@alignbox\relax
168     \fi\fi
169   \fi\fi
170 \else % tate, utod
171   \ifx\box@dir\yoko
172     \if #2t\relax
173       \def\@begin@alignbox{\vtop\bgroup\kern\z@\vbox}%
174       \let\@end@alignbox\egroup
175     \else\if #2b\relax
176       \def\@begin@alignbox{\vbox\bgroup\vbox}%
177       \def\@end@alignbox{\kern\z@\egroup}%
178     \else
179       \let\@begin@alignbox\vcenter
180       \let\@end@alignbox\relax
181     \fi\fi
182   \else\ifx\box@dir\dtou % 180 度回転→vtop, vbox を入れ替える
183     \if #2t\relax
184       \let\@begin@alignbox\vbox %%% !!!
185       \let\@end@alignbox\relax
186     \else\if #2b\relax
187       \let\@begin@alignbox\vtop %%% !!!
188       \let\@end@alignbox\relax
189     \else
190       \let\@begin@alignbox\vcenter
191       \let\@end@alignbox\relax
192     \fi\fi
193   \else
194     \if #2t\relax
195        \let\@begin@alignbox\vtop
196        \let\@end@alignbox\relax
197     \else\if #2b\relax
198        \let\@begin@alignbox\vbox
199        \let\@end@alignbox\relax
200     \else
201        \let\@begin@alignbox\vcenter
202        \let\@end@alignbox\relax
203     \fi\fi
204   \fi\fi
205 \fi\fi%
206 }
207
208 %%% caption
209 \newbox\@floatbox
210 \newdimen\floatwidth
211 \newdimen\floatheight
212 \newdimen\floatruletick \floatruletick=0.4pt
213 \newdimen\captionfloatsep \captionfloatsep=10pt
214 \def\caption@dir{Z}
215 \let\captiondir\relax
216 \newdimen\captionwidth \captionwidth\z@
217 \def\caption@posa{Z}
218 \def\caption@posb{Z}
219 \newbox\@captionbox
220 \def\captionfontsetup{\normalfont\normalsize}
221 \def\layoutfloat{\@ifnextchar(%)
222    {\X@layoutfloat}{\X@layoutfloat(-5\p@,-5\p@)}}
223 \def\X@layoutfloat(#1,#2){\@ifnextchar[%]
224    {\@layoutfloat(#1,#2)}{\@layoutfloat(#1,#2)[c]}}
225 \long\def\@layoutfloat(#1,#2)[#3]#4{%
226   \setbox\z@\hbox{#4}%
227   \floatwidth=#1 \floatheight=#2 \edef\float@pos{#3}%
228   \ifdim\floatwidth<\z@
229      \floatwidth\ltjgetwd\z@\floatruletick\z@
230   \fi
231   \ifdim\floatheight<\z@
232      \floatheight\ltjgetht\z@\advance\floatheight\ltjgetdp\z@\relax
233      \floatruletick\z@
234   \fi
235   \setbox\@floatbox\vbox to\floatheight{\offinterlineskip
236     \hrule width\floatwidth height\floatruletick depth\z@
237     \vss\hbox to\floatwidth{%
238       \vrule width\floatruletick height\floatheight depth\z@
239       \hss\vbox to\floatheight{\hsize\floatwidth\vss#4\vss}\hss
240       \vrule width\floatruletick height\floatheight depth\z@
241     }\hrule width\floatwidth height\floatruletick depth\z@}}
242 \def\DeclareLayoutCaption#1<#2>(#3)[#4#5]{%
243   \expandafter
244   \ifx\csname #1@layoutcaption\endcsname\relax \else
245     \@latex@info{Redeclaring capiton layout setting of '#1'}%
246   \fi
247   \expandafter
248   \gdef\csname #1@layoutcaption\endcsname{%
249      \if Z\caption@dir\def\caption@dir{#2}\fi
250      \ifdim\captionwidth=\z@ \captionwidth=#3\relax\fi
251      \if Z\caption@posa\def\caption@posa{#4}\fi
252      \if Z\caption@posb\def\caption@posb{#5}\fi}}
253 \@onlypreamble\DeclareLayoutCaption
254 \DeclareLayoutCaption{figure}<y>(.8\linewidth)[cd]
255 \DeclareLayoutCaption{table}<y>(.8\linewidth)[cu]
256 \def\layoutcaption{\def\caption@dir{Z}\captionwidth\z@
257   \def\caption@posa{Z}\def\caption@posb{Z}%
258   \@ifnextchar<\X@layoutcaption{%
259     \@ifnextchar(\@ilayoutcaption{%
260       \@ifnextchar[\@iilayoutcaption\relax}}}
261 \def\X@layoutcaption<#1>{\def\caption@dir{#1}%
262   \@ifnextchar(\@ilayoutcaption{%
263     \@ifnextchar[\@iilayoutcaption\relax}}
264 \def\@ilayoutcaption(#1){\setlength\captionwidth{#1}%
265   \@ifnextchar[{\@iilayoutcaption}{\relax}}
266 \def\@iilayoutcaption[#1#2]{%
267   \def\caption@posa{#1}\def\caption@posb{#2}}
268 \def\pcaption{\refstepcounter\@captype \@dblarg{\@pcaption\@captype}}
269 \long\def\@pcaption#1[#2]#3{%
270   \addcontentsline{\csname ext@#1\endcsname}{#1}{%
271     \protect\numberline{\csname the#1\endcsname}{\ignorespaces#2}}%
272   \ifvoid\@floatbox
273      \latex@error{Use with `\protect\layoutfloat'.}\@eha
274   \fi
275   \make@pcaptionbox{#3}%
276   \@pboxswfalse
277   \setbox\@tempboxa\vbox{\hbox to\hsize{\if l\float@pos\else\hss\fi
278     \if l\caption@posb\box\@captionbox\kern\captionfloatsep\fi
279     \if t\caption@posa\vtop
280     \else\if b\caption@posa\vbox
281     \else\ifmmode\vcenter \else\@pboxswtrue $\vcenter \fi\fi\fi
282     {\if u\caption@posb\box\@captionbox\kern\captionfloatsep\fi
283      \unvbox\@floatbox
284      \if d\caption@posb\kern\captionfloatsep\box\@captionbox\fi}%
285     \if r\caption@posb\kern\captionfloatsep\box\@captionbox\fi
286     \if@pboxsw \m@th$\fi \if r\float@pos\else\hss\fi}}%
287   \par\vskip.25\baselineskip
288   \box\@tempboxa}
289 \def\make@pcaptionbox#1{%
290   \expandafter
291   \ifx\csname\@captype @layoutcaption\endcsname\relax
292      \@latex@warning{Default caption layout of `\@captype' unknown.}%
293        \def\caption@dir{Z}\captionwidth\z@
294        \def\caption@posa{Z}\def\caption@posb{Z}%
295   \else
296      \csname \@captype @layoutcaption\endcsname
297   \fi
298   \@tempswafalse
299   % \@tempswa: 基本組の組方向とキャプションの組方向が直交するか?
300   \if y\caption@dir \let\captiondir\yoko
301     \ifodd\ltjgetparameter{direction}\relax\@tempswatrue\fi
302   \else\if z\caption@dir \let\captiondir\relax
303     \ifnum\ltjgetparameter{direction}=3\relax\let\captiondir\utod\fi
304   \else\if d\caption@dir \let\captiondir\dtou
305     \ifodd\ltjgetparameter{direction}\else\@tempswatrue\fi
306   \else\if u\caption@dir \let\captiondir\utod
307     \ifodd\ltjgetparameter{direction}\else\@tempswatrue\fi
308   \else\if t\caption@dir \let\captiondir\tate
309     \ifodd\ltjgetparameter{direction}\else\@tempswatrue\fi
310   \fi\fi\fi\fi\fi
311   \setbox0\hbox{\hbox{\captiondir
312      \captionfontsetup\parindent\z@\inhibitglue
313      \csname fnum@\@captype\endcsname  #1}}%"
314   \if@tempswa\@tempdima\ltjgetht0\relax\else\@tempdima\ltjgetwd0\relax\fi
315   \ifdim\@tempdima>\captionwidth \@tempdima\captionwidth \fi
316   \@pboxswfalse
317   \setbox0\hbox{%
318     \if u\caption@posb\vbox
319     \else\if d\caption@posb\vbox
320     \else\if t\caption@posa\vtop
321     \else\if b\caption@posa\vbox
322     \else\ifmmode\vcenter\else\@pboxswtrue $\vcenter\fi
323     \fi\fi\fi\fi
324     {\hsize\@tempdima\kern\z@
325     \vbox{\captiondir\hsize\@tempdima
326       \captionfontsetup\parindent\z@\inhibitglue
327       \csname fnum@\@captype\endcsname  #1}\kern\z@
328     }\if@pboxsw \m@th$\fi}%
329   \let\to@captionboxwidth\relax
330   \if l\caption@posb \else\if r\caption@posb\else
331   \def\to@captionboxwidth{to\floatwidth}\fi\fi
332   \setbox\@captionbox\hbox\to@captionboxwidth{%
333      \if t\caption@posa\else\hss\fi
334      \unhbox0\relax
335      \if b\caption@posa\else\hss\fi}}
336
337 %%% minipage and parbox
338 \def\minipage{\@ifnextchar<%>
339    {\X@minipage}{\X@minipage<Z>}}
340 \def\X@minipage<#1>{\@ifnextchar[%]
341    {\@iminipage<#1>}{\@iiiminipage<#1>{c}\relax[s]}}
342 \def\@iminipage<#1>[#2]{\@ifnextchar[%]
343    {\@iiminipage<#1>{#2}}{\@iiiminipage<#1>{#2}\relax[s]}}
344 \def\@iiminipage<#1>#2[#3]{\@ifnextchar[%]
345    {\@iiiminipage<#1>{#2}{#3}}{\@iiiminipage<#1>{#2}{#3}[#2]}}
346 \def\@iiiminipage<#1>#2#3[#4]#5{%
347   \leavevmode\bgroup
348   \setlength\@tempdima{#5}%
349   \def\@mpargs{<#1>{#2}{#3}[#4]{#5}}%
350   \let\box@dir\relax
351   \if #1z\relax
352     \ifnum\ltjgetparameter{direction}=3\relax
353       \let\box@dir\utod
354     \fi
355   \else
356     \if #1y\relax     \let\box@dir\yoko
357     \else\if #1t\relax\let\box@dir\tate
358     \else\if #1d\relax\let\box@dir\dtou
359     \else\if #1u\relax\let\box@dir\utod
360     \fi\fi\fi\fi
361   \fi
362   \ifx\box@dir\relax
363     \ifcase\ltjgetparameter{direction}\relax
364        \or   \let\box@dir\dtou
365        \or\or\let\box@dir\tate
366        \or   \let\box@dir\yoko
367        \else \let\box@dir\utod
368     \fi
369   \fi
370   \setbox\@tempboxa\vbox\bgroup\box@dir
371     \adjustbaseline
372     \color@begingroup
373       \hsize\@tempdima
374       \textwidth\hsize \columnwidth\hsize
375       \@parboxrestore
376       \def\@mpfn{mpfootnote}\def\thempfn{\thempfootnote}%
377       \c@mpfootnote\z@
378       \let\@footnotetext\@mpfootnotetext
379       \let\@listdepth\@mplistdepth \@mplistdepth\z@
380       \@minipagerestore
381       \@setminipage}
382 \def\endminipage{%
383     \par
384     \unskip
385     \ifvoid\@mpfootins\else
386       \vskip\skip\@mpfootins
387       \normalcolor
388       \footnoterule
389       \unvbox\@mpfootins
390     \fi
391     \@minipagefalse   %% added 24 May 89
392   \color@endgroup
393   \egroup
394   \expandafter\@iiiparbox\@mpargs{\unvbox\@tempboxa}\egroup}
395 \DeclareRobustCommand\parbox{\@ifnextchar<%>
396    {\X@parbox}{\X@parbox<Z>}}
397 \def\X@parbox<#1>{\@ifnextchar[%]
398    {\@iparbox<#1>}{\@iiiparbox<#1>{c}\relax[s]}}
399 \def\@iparbox<#1>[#2]{\@ifnextchar[%]
400    {\@iiparbox<#1>{#2}}{\@iiiparbox<#1>{#2}\relax[s]}}
401 \def\@iiparbox<#1>#2[#3]{\@ifnextchar[%]%
402    {\@iiiparbox<#1>{#2}{#3}}{\@iiiparbox<#1>{#2}{#3}[#2]}}
403 \long\def\@iiiparbox<#1>#2#3[#4]#5#6{%
404   \leavevmode
405   \setlength\@tempdima{#5}%
406   \fork@parbox@option<#1>[#2]%
407   \@begin@tempboxa\vbox{\box@dir
408     \hsize\@tempdima\@parboxrestore\adjustbaseline#6\@@par}%
409     \ifx\relax#3\else
410       \setlength\@tempdimb{#3}%
411       \edef\@parboxto{to\the\@tempdimb}%
412     \fi
413     \@begin@parbox\@parboxto{\box@dir\adjustbaseline
414        \let\hss\vss\let\unhbox\unvbox
415        \csname bm@#4\endcsname}\@end@parbox
416   \@end@tempboxa}
417 % コミュニティ版では、アスキー版で不自然だった|\parbox|の箱と
418 % 周囲の本文との揃え位置を修正し、以下のように設計しました。
419 % \begin{itemize}
420 % \item 周囲の組方向が横組かつ組方向が|<y>|, |<z>|指定の場合
421 % \begin{itemize}
422 %   \item |[t]|指定のとき\\一行目のベースラインが周囲のそれと一致
423 %   \item |[c]|指定のとき\\箱の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下)
424 %   \item |[b]|指定のとき\\最終行のベースラインが周囲のそれと一致
425 % \end{itemize}
426 % \item 周囲の組方向が横組かつ組方向が|<t>|指定の場合
427 % \begin{itemize}
428 %   \item |[t]|指定のとき\\箱の上端が周囲の和文文字の高さと一致
429 %   \item |[c]|指定のとき\\箱の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下)
430 %   \item |[b]|指定のとき\\箱の下端が周囲の和文文字の深さと一致
431 % \end{itemize}
432 % \item 周囲の組方向が縦組かつ組方向が|<y>|指定の場合
433 % \begin{itemize}
434 %   \item |[t]|指定のとき\\箱の上端が周囲の和文文字の高さと一致
435 %   \item |[c]|指定のとき\\箱の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下)
436 %   \item |[b]|指定のとき\\箱の下端が周囲の和文文字の深さと一致
437 % \end{itemize}
438 % \item 周囲の組方向が縦組かつ組方向が|<t>|指定の場合
439 % \begin{itemize}
440 %   \item |[t]|指定のとき\\一行目のベースラインが周囲のそれと一致
441 %   \item |[c]|指定のとき\\箱の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下)
442 %   \item |[b]|指定のとき\\最終行のベースラインが周囲のそれと一致
443 % \end{itemize}
444 % \item 周囲の組方向が縦組かつ組方向が|<z>|指定の場合
445 %  [TODO] 未定!
446 %^^A \begin{itemize}
447 %^^A   \item |[t]|指定のとき\\箱の上端が周囲の和文ベースラインと一致
448 %^^A   \item |[c]|指定のとき\\箱の中心が周囲の数式軸を通る(欧文ベースラインシフトの影響下)
449 %^^A   \item |[b]|指定のとき\\箱の下端が周囲の和文ベースラインと一致
450 %^^A \end{itemize}
451 % \end{itemize}
452 \def\fork@parbox@option<#1>[#2]{%
453   \let\box@dir\relax
454   \if #1z\relax
455     \ifnum\ltjgetparameter{direction}=3\relax
456       \let\box@dir\utod
457     \fi
458   \else
459     \if #1y\relax     \let\box@dir\yoko
460     \else\if #1t\relax\let\box@dir\tate
461     \else\if #1d\relax\let\box@dir\dtou
462     \else\if #1u\relax\let\box@dir\utod
463     \fi\fi\fi\fi
464   \fi
465   \ifx\box@dir\relax
466     \ifcase\ltjgetparameter{direction}\relax
467        \or   \let\box@dir\dtou
468        \or\or\let\box@dir\tate
469        \or   \let\box@dir\yoko
470        \else \let\box@dir\utod
471     \fi
472   \fi
473 \ifnum\ltjgetparameter{direction}=4 % yoko
474   \ifx\box@dir\yoko
475     \if #2t\relax
476        \let\@begin@parbox\vtop
477        \let\@end@parbox\relax
478     \else\if #2b\relax
479        \let\@begin@parbox\vbox
480        \let\@end@parbox\relax
481     \else
482       \ifmmode
483         \let\@begin@parbox\vcenter\let\@end@parbox\relax
484       \else
485         \def\@begin@parbox{\null$\vcenter}%
486         \def\@end@parbox{\m@th$\null}%
487       \fi
488     \fi\fi
489   \else
490     \if #2t\relax
491        \def\@begin@parbox{\raise\cht\vtop\bgroup\kern\z@\vbox}%
492        \let\@end@parbox\egroup
493     \else\if #2b\relax
494        \def\@begin@parbox{\lower\cdp\vbox\bgroup\vbox}%
495        \def\@end@parbox{\kern\z@\egroup}%
496     \else
497       \ifmmode
498         \let\@begin@parbox\vcenter\let\@end@parbox\relax
499       \else
500         \def\@begin@parbox{\null$\vcenter}%
501         \def\@end@parbox{\m@th$\null}%
502       \fi
503     \fi\fi
504   \fi
505 \else\ifnum\ltjgetparameter{direction}=1 % dtou
506   \ifx\box@dir\yoko
507     \if #2t\relax
508        \def\@begin@parbox{\raise\cht\vtop\bgroup\kern\z@\vbox}%
509        \let\@end@parbox\egroup
510     \else\if #2b\relax
511        \def\@begin@parbox{\lower\cdp\vbox\bgroup\vbox}%
512        \def\@end@parbox{\kern\z@\egroup}%
513     \else
514       \ifmmode
515         \let\@begin@parbox\vcenter\let\@end@parbox\relax
516       \else
517         \def\@begin@parbox{\null$\vcenter}%
518         \def\@end@parbox{\m@th$\null}%
519       \fi
520     \fi\fi
521   \else\ifx\box@dir\dtou
522     \if #2t\relax
523        \let\@begin@parbox\vtop
524        \let\@end@parbox\relax
525     \else\if #2b\relax
526        \let\@begin@parbox\vbox
527        \let\@end@parbox\relax
528     \else
529       \ifmmode
530         \let\@begin@parbox\vcenter\let\@end@parbox\relax
531       \else
532         \def\@begin@parbox{\null$\vcenter}%
533         \def\@end@parbox{\m@th$\null}%
534       \fi
535     \fi\fi
536   \else % 180 度回転→vtop, vbox を入れ替える
537     \if #2t\relax
538        \let\@begin@parbox\vbox %%% !!!
539        \let\@end@parbox\relax
540     \else\if #2b\relax
541        \let\@begin@parbox\vtop %%% !!!
542        \let\@end@parbox\relax
543     \else
544       \ifmmode
545         \let\@begin@parbox\vcenter\let\@end@parbox\relax
546       \else
547         \def\@begin@parbox{\null$\vcenter}%
548         \def\@end@parbox{\m@th$\null}%
549       \fi
550     \fi\fi
551   \fi\fi
552 \else % tate, utod
553   \ifx\box@dir\yoko
554     \if #2t\relax
555       \def\@begin@parbox{\raise\cht\vtop\bgroup\kern\z@\vbox}%
556       \let\@end@parbox\egroup
557     \else\if #2b\relax
558       \def\@begin@parbox{\lower\cdp\vbox\bgroup\vbox}%
559       \def\@end@parbox{\kern\z@\egroup}%
560     \else
561       \ifmmode
562         \let\@begin@parbox\vcenter\let\@end@parbox\relax
563       \else
564         \def\@begin@parbox{\null$\vcenter}%
565         \def\@end@parbox{\m@th$\null}%
566       \fi
567     \fi\fi
568   \else\ifx\box@dir\dtou % 180 度回転→vtop, vbox を入れ替える
569     \if #2t\relax
570       \let\@begin@parbox\vbox %%% !!!
571       \let\@end@parbox\relax
572     \else\if #2b\relax
573       \let\@begin@parbox\vtop %%% !!!
574       \let\@end@parbox\relax
575     \else
576       \ifmmode
577         \let\@begin@parbox\vcenter\let\@end@parbox\relax
578       \else
579         \def\@begin@parbox{\null$\vcenter}%
580         \def\@end@parbox{\m@th$\null}%
581       \fi
582     \fi\fi
583   \else
584     \if #2t\relax
585        \let\@begin@parbox\vtop
586        \let\@end@parbox\relax
587     \else\if #2b\relax
588        \let\@begin@parbox\vbox
589        \let\@end@parbox\relax
590     \else
591       \ifmmode
592         \let\@begin@parbox\vcenter\let\@end@parbox\relax
593       \else
594         \def\@begin@parbox{\null$\vcenter}%
595         \def\@end@parbox{\m@th$\null}%
596       \fi
597     \fi\fi
598   \fi\fi
599 \fi\fi%
600 }
601
602 %%% pbox
603 \DeclareRobustCommand\pbox{\leavevmode\@ifnextchar<{\X@makePbox}{\X@makePbox<Z>}}
604 \def\X@makePbox<#1>{%
605   \@ifnextchar[{\@imakePbox<#1>}{\@imakePbox<#1>[-5\p@]}}
606 \def\@imakePbox<#1>[#2]{\@ifnextchar[%]
607   {\@iimakePbox<#1>{#2}}{\@iimakePbox<#1>{#2}[c]}}
608 \def\@iimakePbox<#1>#2[#3]#4{%
609   \bgroup\let\box@dir\relax
610   \if #1z\relax
611     \ifnum\ltjgetparameter{direction}=3 \relax
612       \let\box@dir\utod
613     \fi
614   \else
615     \if #1y\relax     \let\box@dir\yoko
616     \else\if #1t\relax\let\box@dir\tate
617     \else\if #1d\relax\let\box@dir\dtou
618     \else\if #1u\relax\let\box@dir\utod
619     \fi\fi\fi\fi
620   \fi
621   \ifx\box@dir\relax
622     \ifcase\ltjgetparameter{direction}
623        \or   \let\box@dir\dtou
624        \or\or\let\box@dir\tate
625        \or   \let\box@dir\yoko
626        \else \let\box@dir\utod
627     \fi
628   \fi
629     \setlength{\@tempdima}{#2}%
630     \ifdim\@tempdima<\z@ \hbox{\box@dir#4}\else
631     \hb@xt@\@tempdima{\box@dir
632                \if #3l\relax\else\hss\fi
633                #4\relax
634                \if #3r\relax\else\hss\fi}\fi\egroup}
635
636 %%% picture
637 \def\picture{\@ifnextchar<%>
638    {\X@picture}{\X@picture<Z>}}
639 \def\X@picture<#1>(#2,#3){\@ifnextchar(%)
640    {\@@picture<#1>(#2,#3)}{\@@picture<#1>(#2,#3)(0,0)}}
641 \newdimen\@picwd
642 \def\ltj@@pic@reset@blshift{%
643   \ltj@yablshift\z@\ltj@ykblshift\z@
644   \ltj@tablshift\z@\ltj@tkblshift\z@
645 }%
646 \def\@@picture<#1>(#2,#3)(#4,#5){%
647   \edef\ltj@@pic@save@blshift{%
648     \noexpand\ltj@yablshift\the\ltj@yablshift\noexpand\relax
649     \noexpand\ltj@ykblshift\the\ltj@ykblshift\noexpand\relax
650     \noexpand\ltj@tablshift\the\ltj@tablshift\noexpand\relax
651     \noexpand\ltj@tkblshift\the\ltj@tkblshift\noexpand\relax
652   }%
653   \bgroup\let\box@dir\relax
654   \if #1z\relax
655     \ifnum\ltjgetparameter{direction}=3 \relax
656       \let\box@dir\utod
657     \fi
658   \else
659     \if #1y\relax     \let\box@dir\yoko
660     \else\if #1t\relax\let\box@dir\tate
661     \else\if #1d\relax\let\box@dir\dtou
662     \else\if #1u\relax\let\box@dir\utod
663     \fi\fi\fi\fi
664   \fi
665   \ifx\box@dir\relax
666     \ifcase\ltjgetparameter{direction}
667        \or   \let\box@dir\dtou
668        \or\or\let\box@dir\tate
669        \or   \let\box@dir\yoko
670        \else \let\box@dir\utod
671     \fi
672   \fi
673   \@picwd=#2\unitlength \@picht=#3\unitlength
674   \setbox\@picbox\hbox to\@picwd\bgroup\box@dir
675   \hskip-#4\unitlength\lower#5\unitlength\hbox\bgroup
676   \ltj@@pic@reset@blshift
677   \ignorespaces}
678 \def\endpicture{%
679   \egroup\hss\egroup
680   \setbox0=\hbox{\box@dir%
681     \ltjsetht\@picbox\@picht \ltjsetdp\@picbox\z@
682   }%
683   \@tempswafalse
684   \ifnum\ltjgetparameter{direction}=3  \@tempswatrue\fi
685   \ifnum\ltjgetparameter{direction}=11  \@tempswatrue\fi
686   \if@tempswa
687     \ifx\box@dir\yoko % この場合だけ垂直位置補正が必要
688      \ltjsetht\@picbox\dimexpr\ltjgetht\@picbox+\ltjgetdp\@picbox\relax
689       \ltjsetdp\@picbox\z@
690     \fi
691   \fi
692   \mbox{\box\@picbox}%
693   \egroup\ltj@@pic@save@blshift}
694 \let\org@put\put
695 \def\put{\ltj@@pic@reset@blshift\org@put}
696 \let\org@line\line
697 \def\line{\ltj@@pic@reset@blshift\org@line}
698 \let\org@vector\vector
699 \def\vector{\ltj@@pic@reset@blshift\org@vector}
700 \let\org@dashbox\dashbox
701 \def\dashbox{\ltj@@pic@reset@blshift\org@dashbox}
702 \let\org@oval\oval
703 \def\oval{\ltj@@pic@reset@blshift\org@oval}
704 \let\org@circle\circle
705 \def\circle{\ltj@@pic@reset@blshift\org@circle}
706
707 %%% rensuji
708 \newif\ifnot@advanceline
709 \newskip\rensujiskip
710 \rensujiskip=0.25\chs plus.25\zw minus.25\zw
711 \DeclareRobustCommand\rensuji{%
712   \@ifstar{\not@advancelinetrue\@rensuji}{\@rensuji}}
713 \def\@rensuji{\@ifnextchar[{\@@rensuji}{\@@rensuji[c]}}
714 \def\@@rensuji[#1]#2{%
715   \ifvmode\leavevmode\fi
716   \ifnum\ltjgetparameter{direction}=4\relax\hbox{#2}\else
717   \hskip\rensujiskip
718   \setbox\tw@\hbox{漢}% 「あ」では仮名書体使用時がまずそう
719   \@tempdimb\ltjgetht\tw@ \advance\@tempdimb\ltjgetdp\tw@
720   \ifnot@advanceline\not@advancelinefalse\else
721     \setbox\z@\hbox{\yoko#2}%
722     \@tempdima\ltjgetht\z@ \advance\@tempdima\ltjgetdp\z@
723     \ifnum\ltjgetparameter{direction}=1\relax
724       % 周囲が dtou の場合には,高さ \ltjgetht\tw@, 深さ \ltjgetdp\tw@ のボックスを基準としている.
725       \if #1c\relax\vrule \@width \z@ \@height\dimexpr.5\@tempdima+.5\ltjgetht\tw@-.5\ltjgetdp\tw@
726                           \@depth\dimexpr.5\@tempdima-.5\ltjgetht\tw@+.5\ltjgetdp\tw@
727       \else\if #1l\relax\vrule\@width \z@\@height\ltjgetht\tw@ \@depth\dimexpr\@tempdima-\ltjgetht\tw@
728       \else\vrule\@width \z@ \@height\dimexpr\@tempdima-\ltjgetdp\tw@ \@depth\ltjgetdp\tw@
729       \fi\fi
730     \else
731       % 周囲が tate, utod の場合も同じ
732       \if #1c\relax\vrule \@width \z@ \@height\dimexpr.5\@tempdima+.5\ltjgetht\tw@-.5\ltjgetdp\tw@
733                           \@depth\dimexpr.5\@tempdima-.5\ltjgetht\tw@+.5\ltjgetdp\tw@
734       \else\if #1r\relax\vrule\@width \z@\@height\ltjgetht\tw@ \@depth\dimexpr\@tempdima-\ltjgetht\tw@
735       \else\vrule\@width \z@ \@height\dimexpr\@tempdima-\ltjgetdp\tw@ \@depth\ltjgetdp\tw@
736       \fi\fi
737     \fi
738   \fi
739   \ifnum\ltjgetparameter{direction}=1\relax
740     \if #1c\relax\hbox to\@tempdimb{\yoko\hss#2\hss\kern-\ltjgetdp\tw@}%
741     \else\if #1r\relax\vbox{\hbox to\@tempdimb{\yoko\hss#2\kern-\ltjgetdp\tw@}}%
742     \else\lower\ltjgetdp\tw@\vtop{\hbox to\@tempdimb{\yoko#2\hss}}%
743     \fi\fi
744   \else
745     \if #1c\relax\raise\dimexpr.5\@tempdimb-\ltjgetdp\tw@
746         \hbox to\@tempdimb{\yoko \hss#2\hss}%
747     \else\if #1r\relax\raise\dimexpr.5\@tempdimb-\ltjgetdp\tw@
748         \vbox{\hbox to\@tempdimb{\yoko\hss#2}}%
749     \else\raise\dimexpr.5\@tempdimb-\ltjgetdp\tw@
750          \vtop{\hbox to\@tempdimb{\yoko #2\hss}}%
751     \fi\fi
752   \fi
753   \hskip\rensujiskip
754 \fi}
755 \let\Rensuji\rensuji
756 \let\prensuji\rensuji
757
758 %%% kanji
759 \def\Kanji#1{\expandafter\@Kanji\csname c@#1\endcsname}
760 \def\@Kanji#1{\kansuji #1}
761 \def\kanji{\ifnum\ltjgetparameter{direction}=3 \expandafter\kansuji\fi}
762
763 %%% bou
764 %%%
765 \def\boutenchar{\char\euc"A1A2}%"
766 \def\bou#1{\ifvmode\leavevmode\fi\@bou#1\end}
767 \def\@bou#1{%
768   \ifx#1\end \let\next=\relax
769   \else
770     \ifnum\ltjgetparameter{direction}=3\relax
771       \hbox to\z@{\vbox to\z@{\boxmaxdepth\maxdimen
772         \vss\moveleft0.2\zw\hbox{\yoko\boutenchar}\nointerlineskip
773         \hbox{\char\euc"A1A1}}\hss}\nobreak#1\relax
774     \else
775       \hbox to\z@{\vbox to\z@{\boxmaxdepth\maxdimen
776         \vss\moveleft-0.2\zw\hbox{\boutenchar}\nointerlineskip
777         \hbox{\char\euc"A1A1}}\hss}\nobreak#1\relax
778     \fi
779     \let\next=\@bou
780   \fi\next}
781
782 %%% kasen
783 \def\kasen#1{%
784   \ifnum\ltjgetparameter{direction}=3\relax
785     \setbox\z@\hbox{#1}\leavevmode\raise.7\zw
786     \hbox to\z@{\vrule\@width\wd\z@ \@depth\z@ \@height.4\p@\hss}%
787     \box\z@
788   \else\underline{#1}\fi}
789
790 %%% references
791 \def\@eqnnum{{\reset@font\rmfamily \normalcolor
792   \ifnum\ltjgetparameter{direction}=11\raise.25\zh\hbox{\yoko(\theequation)}%
793   \else (\theequation)\fi}}
794 \def\@thecounter#1{\noexpand\rensuji{\noexpand\arabic{#1}}}
795 \def\@thmcounter#1{\noexpand\rensuji{\noexpand\arabic{#1}}}
796
797 %% Compatibility with array package
798
799 \def\ltj@lltjext@patch@array{%
800   \patchcmd{\@tabular}{\hbox\bgroup}{%
801         \hbox\bgroup\count@=\ltjgetparameter{direction}}{}{}
802   \def\@startpbox##1{\bgroup
803    \box@dir\adjustbaseline%%% これを追加
804    \hsize=##1\@arrayparboxrestore
805      \everypar{%
806         \vrule \@height \ltjgetht\@arstrutbox \@width \z@
807         \everypar{}}%
808      }
809   \def\@tabarray{\@ifnextchar<\p@tabarray{\p@tabarray<Z>}}
810   \def\p@array<##1>[##2]##3{%
811     \let\box@dir\relax
812     \if ##1z\relax
813       \ifnum\count@=3\relax
814         \let\box@dir\utod\@tempcnta=\zstrutbox
815       \fi
816     \else
817       \if ##1y\relax
818         \let\box@dir\yoko\@tempcnta=\ystrutbox
819       \else\if ##1t\relax
820         \let\box@dir\tate\@tempcnta=\tstrutbox
821       \else\if ##1d\relax
822          \let\box@dir\dtou\@tempcnta=\dstrutbox
823       \else\if ##1u\relax
824          \let\box@dir\utod\@tempcnta=\zstrutbox
825       \fi\fi\fi\fi
826     \fi
827     \ifx\box@dir\relax
828       \ifcase\count@
829          \or   \let\box@dir\dtou\@tempcnta=\dstrutbox% dtou
830          \or\or\let\box@dir\tate\@tempcnta=\tstrutbox% tate
831          \or   \let\box@dir\yoko\@tempcnta=\ystrutbox% yoko
832          \else \let\box@dir\utod\@tempcnta=\zstrutbox% utod
833       \fi
834     \fi
835     \setbox \@arstrutbox \hbox{\box@dir\vrule
836                \@height \arraystretch
837                  \dimexpr \ltjgetht\@tempcnta+\extrarowheight\relax
838                \@depth \arraystretch \ltjgetdp \@tempcnta
839                \@width \z@}%
840     \fork@array@option<##1>[##2]%
841     \begingroup
842     \@mkpream{##3}%
843     \xdef\@preamble{\ialign \noexpand \@halignto
844                     \bgroup \tabskip \z@skip \@arstrut \@preamble
845                             \tabskip \z@ \cr}%
846     \endgroup
847     \@arrayleft
848     \@begin@alignbox\bgroup\box@dir\adjustbaseline
849       \let\par\@empty
850       \let\@sharp####\let\protect\relax
851       \let\\\@arraycr\let\tabularnewline\\\let\par\@empty
852      \lineskip\z@skip\baselineskip\z@skip\@preamble}
853   \def\endarray{\crcr\egroup\egroup\@end@alignbox\@arrayright}
854 }
855
856 \@ifpackageloaded{array}{%
857   \expandafter\let\csname tabular*\endcsname=\ltj@lltjext@orig@tabularS
858   \let\tabular=\ltj@lltjext@orig@tabular
859   \let\array=\ltj@lltjext@orig@array
860   \ltj@lltjext@patch@array
861 }{%
862   \let\ltj@lltjext@orig@tabularS\relax
863   \let\ltj@lltjext@orig@tabular\relax
864   \let\ltj@lltjext@orig@array\relax
865   \RequirePackage{filehook,etoolbox}
866   \AtEndOfPackageFile{array}{\ltj@lltjext@patch@array}
867 }
868
869 %%%%%%%%%%%%%%%% LuaTeX-ja original
870
871 \define@key[ltj]{japaram}{autouprightnum}{%      %COUNT
872   \ltj@@set@stack{AURN}{0}{10000}\z@#1 }
873
874 \endinput