OSDN Git Service

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