5 \def\@fornoop#1\@@#2#3{}%
6 \long\def\@for#1:=#2\do#3{%
7 \expandafter\def\expandafter\@fortmp\expandafter{#2}%
8 \ifx\@fortmp\@empty \else
9 \expandafter\@forloop#2,\@nil,\@nil\@@#1{#3}
11 \long\def\@forloop#1,#2,#3\@@#4#5{%
16 \else#5\@iforloop #3\@@#4{#5}
19 \long\def\@iforloop#1,#2\@@#3#4{\def#3{#1}\ifx #3\@nnil
20 \expandafter\@fornoop \else
21 #4\relax\expandafter\@iforloop\fi#2\@@#3{#4}}%
22 \def\@tfor#1:={\@tf@r#1 }%
23 \long\def\@tf@r#1#2\do#3{\def\@fortmp{#2}\ifx\@fortmp\space\else
24 \@tforloop#2\@nil\@nil\@@#1{#3}\fi}%
25 \long\def\@tforloop#1#2\@@#3#4{\def#3{#1}\ifx #3\@nnil
26 \expandafter\@fornoop \else
27 #4\relax\expandafter\@tforloop\fi#2\@@#3{#4}}%
28 \long\def\@ifnextchar#1#2#3{%
32 \futurelet\@let@token\@ifnch}
34 \ifx\@let@token\@sptoken
35 \let\reserved@c\@xifnch
37 \ifx\@let@token\reserved@d
38 \let\reserved@c\reserved@a
40 \let\reserved@c\reserved@b
44 \def\:{\let\@sptoken= } \: % this makes \@sptoken a space token
45 \def\:{\@xifnch} \expandafter\def\: {\futurelet\@let@token\@ifnch}
47 \ifx\xguji@defined\@undefined
48 \def\xguji@defined{\relax}
49 %% punctuation prohibition testing module
50 \def\linestartforbid{,.!?'、。,.:;!?’”〕)]}〉》〗】」』}
51 \def\lineendforbid{`‘“〔([{〈《〖【「『}
52 \ifx\testinset\@undefined
54 \long\def\testinset#1#2{% return whether #1 is in the set of #2, result stored in \ifisinset
58 \expandafter\@tfor\expandafter\testinset@member
59 \expandafter:\expandafter=#2\do{%
60 \if\testinset@member #1%
66 \def\testcharinset#1#2{% test whether character #1 is in #2, not using tfor
67 \def\t@ctest##1{\expandafter\t@ct@st ##1#1\t@ctest\t@ct@st}%
68 \def\t@ct@st##1#1##2##3\t@ct@st{\ifx\t@ctest##2\isinsetfalse
69 \else\isinsettrue\fi}%
70 \t@ctest{\noexpand #2}%
73 \def\getlastelem#1#2{% return the last tfor element of #1, stored in #2
74 \expandafter\@tfor\expandafter\getlastelem@member\expandafter:\expandafter=#1\do{%
75 \edef#2{\getlastelem@member}%
78 \def\testbreak#1#2#3{% #1: \output #2: \lasttext #3:\nowchar return \output if breakable
83 \getlastelem{#2}\lastchar
84 \testinset\lastchar\lineendforbid
85 \ifisinset % \lastchar is a line-end prohibition, which cannot be at the end of line
88 \testinset\lastchar\linestartforbid
89 \ifisinset % \lastchar is a line-start prohibition, which cannot appear at the start of line
90 \testinset{#3}\linestartforbid
91 \ifisinset % \nowchar is a line-start prohibition, which should be appended after \lasttext
93 \else % \nowchar is not a line-start prohibition. Can break after \lasttext
97 \else % \lastchar is a normal char
98 \testinset{#3}\linestartforbid
99 \ifisinset % \nowchar is a line-start prohibition, which make the place after \lasttext unbreakable
101 \else % \nowchar is not a line-start prohibition. Can break after \lasttext
109 %% list manipulation module
110 \def\getnumofelem#1#2{% return the num of element of #1, stored in counter #2
112 \if!#1!% test whether #1 is non-empty
114 \expandafter\@for\expandafter\getnumofelem@member
115 \expandafter:\expandafter=#1\do{%
120 \ifx\getforitem\@undefined
121 \newcount\getforitem@tmpcount
122 \def\getforitem#1#2#3{% #1: for list #2: index #3: output macro
123 \getforitem@tmpcount=0
124 \expandafter\@for\expandafter\getitem@member\expandafter:\expandafter=#1\do{%
125 \ifnum\getforitem@tmpcount = #2%
126 \edef#3{\getitem@member}%
128 \advance\getforitem@tmpcount by 1
133 \input ltj-warichu-hsplit.sty
136 \newdimen\guji@hoffset
137 \newdimen\guji@twolineraise
139 \newskip\guji@hanzisep
142 \newif\ifguji@heavydebug
143 \newdimen\guji@tmpdim
144 \newdimen\guji@tmpdil
145 \newcount\guji@tmpcount
148 \newtoks\guji@everytwolinemode
149 \newtoks\guji@everycommand
151 \guji@heavydebugfalse
152 \guji@hanzisep=0pt plus 0.1em minus 0.1em
153 \guji@twolineraise=-.3ex
155 \guji@everytwolinemode={\fiverm\baselineskip=6pt}
156 \guji@everycommand={\parindent=2em\indent}
159 \everypar{\guji@iterate}%
160 \everyvbox{\everypar{}}%
164 \rightskip=0pt plus 0.1em minus 0.1em
166 \def\guji@lasttext{}%
168 \guji@adjustsectioncmd
171 \def\guji@adjustcmd#1#2{%
175 %\def#1{{\ifvmode\vskip -\baselineskip\vskip -\parsep\fi}\leavevmode #2}%
176 \def#1{\leavevmode #2}%
179 \def\guji@adjustsectioncmd{%
180 \guji@adjustcmd\part\guji@oldpart
181 \guji@adjustcmd\chapter\guji@oldchapter
182 \guji@adjustcmd\section\guji@oldsection
183 \guji@adjustcmd\subsection\guji@oldsubsection
184 \guji@adjustcmd\subsubsection\guji@oldsubsubsection
185 \guji@adjustcmd\paragraph\guji@oldparagraph
190 \gdef\guji@makespecials{%
196 \@ifnextchar[{\guji@sp@cial}{\guji@twolinemode}% ]
198 \def\guji@sp@cial[#1]#2{% #1 is a comma-seperated list of command names
200 \message{special \meaning #1 \meaning #2}%
206 \getnumofelem{#1}\guji@tmpcount%
207 \ifcase\guji@tmpcount
209 \message{Zero}% just a local group
211 \def\guji@lasttext{{#2}}%
215 \message{One}% a command that applies to the entire #2
217 \def\guji@lasttext{{\csname #1\endcsname{#2}}}%
221 \message{Two}% execute the first command, then apply the second to #2
224 \def\guji@lasttext{{\csname #1\endcsname{#2}}}%
228 \message{Three}% #1,#2,#3, apply #1 #2 #3 to the first, middle, last char
230 % if #1 empty, #1<-#2; if #3 empty, #3<-#2
231 \def\guji@sp@docmd##1##2{%
232 \def\guji@lasttext{{##1{##2}}}%
236 \guji@sp@cial@three[#1]#2\end
238 \errmessage{guji@sp@cial: Unsupported option #1.}%
240 \global\guji@tmpdim=\guji@hoffset
243 \guji@hoffset=\guji@tmpdim
244 \guji@iterate % continue to iterate
246 \def\guji@sp@cial@three[#1,#2,#3]#4#5\end{%
247 \expandafter\let\expandafter\guji@sp@middle\csname #2\endcsname
249 \let\guji@sp@first=\guji@sp@middle
251 \expandafter\let\expandafter\guji@sp@first\csname #1\endcsname
254 \let\guji@sp@last=\guji@sp@middle
256 \expandafter\let\expandafter\guji@sp@last\csname #3\endcsname
259 \message{first is #4 by \meaning\guji@sp@first}%
261 \guji@sp@docmd\guji@sp@first{#4}%
262 \def\guji@sp@midtext{}%
263 \def\guji@sp@lasttext{}%
264 \@tfor\guji@sp@member:=#5\do{%
265 \edef\guji@sp@midtext{\guji@sp@lasttext}%
266 \edef\guji@sp@lasttext{\guji@sp@member}%
267 \ifx\guji@sp@midtext\empty
269 \expandafter\guji@sp@docmd\expandafter\guji@sp@middle
270 \expandafter{\guji@sp@midtext}%
272 \message{middle is \guji@sp@midtext by \meaning\guji@sp@middle}%
276 \expandafter\guji@sp@docmd\expandafter\guji@sp@last
277 \expandafter{\guji@sp@lasttext}%
279 \message{last is \guji@sp@lasttext by \meaning\guji@sp@last}%
282 \def\guji@twoline@sp@cial[#1]#2{% #1 is a comma-seperated list of command names
284 \message{special \meaning #1 \meaning #2}%
286 \getnumofelem{#1}\guji@tmpcount%
287 \ifcase\guji@tmpcount
289 \message{Zero}% just a local group
291 \setbox\guji@savebox=\hbox{\unhbox\guji@savebox{#2}\allowbreak\hskip\guji@hanzisep}%
294 \message{One}% a command that applies to the entire #2
296 \setbox\guji@savebox=\hbox{\unhbox\guji@savebox{{\csname #1\endcsname{#2}}}\allowbreak\hskip\guji@hanzisep}%
299 \message{Two}% execute the first command, then apply the second to #2
302 \setbox\guji@savebox=\hbox{\unhbox\guji@savebox{{\csname #1\endcsname{#2}}}\allowbreak\hskip\guji@hanzisep}%
305 \message{Three}% #1,#2,#3, apply #1 #2 #3 to the first, middle, last char
307 % if #1 empty, #1<-#2; if #3 empty, #3<-#2
308 \def\guji@sp@docmd##1##2{%
309 \setbox\guji@savebox=\hbox{\unhbox\guji@savebox{##1{##2}}\allowbreak\hskip\guji@hanzisep}%
311 \guji@sp@cial@three[#1]#2\end
313 \errmessage{guji@twoline@sp@cial: Unsupported option #1.}%
315 \guji@twoline@iterate % continue to iterate
317 \def\guji@twolinemode#1{%
321 \the\guji@everytwolinemode
322 \let\guji@sp@cial\guji@twoline@sp@cial % no nest allowed
323 \let\guji@twolinemode\guji@twoline@iterate % no nest allowed
324 \setbox\guji@savebox=\hbox{}%
325 \hfuzz=\maxdimen\hbadness=\@M
327 \guji@twoline@iterate
328 #1\guji@twoline@enditer
329 \global\guji@tmpdim=\guji@hoffset
331 \guji@hoffset=\guji@tmpdim
332 \guji@iterate % continue to iterate
334 \def\guji@twoline@iterate#1{%
335 %\message{iterating \meaning#1}%
336 \ifx #1\guji@twoline@enditer
337 \guji@twoline@enditer
339 \let\guji@twoiter@next\guji@twoline@iterate
342 \let\guji@twoiter@next\guji@special
344 \testbreak\guji@oktext\guji@lasttext{#1}%
345 \ifx\guji@oktext\empty
347 %\setbox\guji@tmpbox=\hbox{\unhcopy\guji@savebox[\guji@oktext]\allowbreak}%
348 \setbox\guji@tmpbox=\hbox{\unhcopy\guji@savebox\guji@oktext\allowbreak\hskip\guji@hanzisep}%
349 \guji@tmpdim=\wd\guji@tmpbox
350 \divide\guji@tmpdim by 2
351 \advance\guji@tmpdim by \guji@hoffset
352 \advance\guji@tmpdim by -\guji@hfuzz
353 \ifdim\guji@tmpdim > \guji@hsize % a break is required
354 \guji@tmpdim=\guji@hsize
355 \advance\guji@tmpdim by -\guji@hoffset
357 %\setbox\guji@savebox=\hbox{\guji@oktext\allowbreak\hskip\guji@hanzisep}%
358 \setbox\guji@savebox=\hbox{\unhbox\guji@savebox\guji@oktext\allowbreak\hskip\guji@hanzisep}%
360 %\setbox\guji@savebox=\hbox{\unhbox\guji@savebox[\guji@oktext]\allowbreak}%
361 \setbox\guji@savebox=\hbox{\unhbox\guji@savebox\guji@oktext\allowbreak\hskip\guji@hanzisep}%
365 \expandafter\guji@twoiter@next
368 \def\guji@twoline@flush{% \guji@tmpdim is required to be presetted
372 \setbox\guji@tmpboy=\copy\guji@savebox % make a backup of savebox
373 \let\guji@twoline@break\relax
374 \hsplit\guji@savebox\to\guji@tmpdim\into\guji@tmpbox
375 \guji@tmpdil=\wd\guji@tmpbox
376 \advance\guji@tmpdil by -\guji@tmpdim
377 \ifdim\guji@tmpdil > \guji@hfuzz
378 %\showbox\guji@tmpboy
379 \guji@tmpdim=\wd\guji@tmpbox
381 % \advance\guji@tmpdim by \wd\guji@tmpbox
382 % \divide\guji@tmpdim by 2
384 \ifdim\guji@tmpdim < \wd\guji@savebox % the second box is longer than the first, should be truncated
385 \setbox\guji@tmpbox=\hbox to \guji@tmpdim{\unhbox\guji@tmpbox}%
386 \hsplit\guji@savebox\to\guji@tmpdim\into\guji@tmpboy
387 \setbox\guji@tmpboy=\hbox to \guji@tmpdim{\unhbox\guji@tmpboy\hss}%
389 \advance\guji@tmpdim by \guji@hoffset
390 \ifdim\guji@tmpdim > \guji@hsize % at the end of line, should break in advance
391 \let\guji@twoline@break\break
393 \else % the first box is longer than the second
395 \advance\guji@tmpdim by \guji@hoffset
396 \ifdim\guji@tmpdim > \guji@hsize % at the end of line, should break in advance
398 \let\guji@twoline@break\break
399 \advance\guji@tmpdim by -\guji@hoffset
400 \advance\guji@tmpdim by -2\guji@hfuzz
401 \setbox\guji@savebox=\hbox{\allowbreak\unhcopy\guji@tmpboy}%
402 \hsplit\guji@savebox\to\guji@tmpdim\into\guji@tmpbox
403 \guji@tmpdim=\wd\guji@tmpbox
404 %\showbox\guji@tmpbox
405 % now the first box should be shorter than the second. if not, just go on.
406 %\setbox\guji@tmpbox=\hbox to \guji@tmpdim{\unhbox\guji@tmpbox}%
407 \guji@tmpdil=\wd\guji@savebox
408 \advance\guji@tmpdil by -\guji@tmpdim
409 \ifdim\guji@tmpdil < 0pt
410 \guji@tmpdil=-\guji@tmpdil
412 \ifdim\guji@tmpdil > \guji@hfuzz
413 \setbox\guji@savebox=\hbox{\allowbreak\unhcopy\guji@savebox}%
414 \hsplit\guji@savebox\to\guji@tmpdim\into\guji@tmpboy
415 \setbox\guji@tmpboy=\hbox to \guji@tmpdim{\unhbox\guji@tmpboy\hss}%
417 \advance\guji@tmpdim by \wd\guji@savebox
418 \divide\guji@tmpdim by 2
419 \setbox\guji@tmpbox=\hbox to \guji@tmpdim{\unhbox\guji@tmpbox}%
420 \setbox\guji@tmpboy=\hbox to \guji@tmpdim{\unhbox\guji@savebox\hss}%
421 %\setbox\guji@savebox=\hbox{}%
423 %\showbox\guji@tmpboy
424 %\showbox\guji@savebox
426 \advance\guji@tmpdim by -\guji@hoffset
427 \setbox\guji@tmpbox=\hbox to \guji@tmpdim{\unhbox\guji@tmpbox}%
428 \setbox\guji@tmpboy=\hbox to \guji@tmpdim{\unhbox\guji@savebox\hss}%
429 %\setbox\guji@savebox=\hbox{}%
434 \setbox\guji@tmpbox=\hbox to \guji@tmpdim{\unhbox\guji@tmpbox}%
435 \setbox\guji@tmpboy=\hbox to \guji@tmpdim{\unhbox\guji@savebox\hskip 0pt plus 1fil}%
436 %\setbox\guji@savebox=\hbox{}%
438 \setbox\guji@tmpbox=\hbox to \guji@tmpdim{\vbox{\hsize=\guji@tmpdim
439 \nointerlineskip\box\guji@tmpbox\box\guji@tmpboy}}%
441 \raise\guji@twolineraise\box\guji@tmpbox
443 \advance\guji@hoffset by \guji@tmpdim
444 \ifx\guji@twoline@break\break
445 \penalty -9999 % issue a break
448 \guji@tmpdim=\guji@hoffset
449 \advance\guji@tmpdim by \guji@hfuzz
450 \ifdim\guji@tmpdim > \guji@hsize
451 \penalty -9999 % issue a break
456 \def\guji@twoline@enditer{%
458 \edef\guji@oktext{\guji@lasttext}%
459 \def\guji@lasttext{}%
460 \setbox\guji@savebox=\hbox{\unhcopy\guji@savebox\guji@oktext\hskip\guji@hanzisep}%
461 \guji@tmpdim=\wd\guji@savebox
462 \divide\guji@tmpdim by 2
463 % search to find a proper hbox width to break
466 \setbox\guji@tmpboy=\copy\guji@savebox
467 \hsplit\guji@tmpboy\to\guji@tmpdim\into\guji@tmpbox
469 \guji@tmpdil=\wd\guji@tmpbox
470 \ifdim\guji@tmpdil < \wd\guji@tmpboy % failed
471 \global\advance\guji@tmpdim by 0.5ex
474 %\showbox\guji@tmpbox
477 %\message{iteration ended}%
479 \def\guji@docommand{%
481 \message{Starting do command \meaning\guji@whatcmd}%
483 \def\guji@whatparam{}%
484 \futurelet\guji@nextchar\guji@d@command
486 \def\guji@d@command{%
487 \ifcat\noexpand\guji@nextchar\bgroup
488 \let\guji@docmd@next\guji@docmd@saveparam
490 \let\guji@docmd@next\guji@docomm@nd
491 \ifx\guji@whatcmd\unhbox
492 \ifx\guji@whatparam\empty
493 \let\guji@docmd@next\guji@docmd@saveparam
499 \long\def\guji@docmd@saveparam#1{%
501 \message{Param #1 saved}%
503 \edef\guji@whatparam{\guji@whatparam{#1}}%
504 \futurelet\guji@nextchar\guji@d@command
506 \def\guji@docomm@nd{%
508 \message{Now doing command}%
510 \ifx\guji@whatcmd\unhbox
511 \expandafter\def\expandafter\guji@whatparam\guji@whatparam
513 \def\guji@tmpparam{\voidb@x}%
514 \ifx\guji@whatparam\guji@tmpparam
515 % the command is leavevmode. just execute it
516 \expandafter\guji@whatcmd\guji@whatparam
520 \the\guji@everycommand
521 \expandafter\guji@whatcmd\guji@whatparam
528 \long\def\guji@iterate#1{%
529 %\message{ITERATing \meaning#1}%
538 \let\guji@iterate@next\guji@iterate
541 \let\guji@iterate@next\guji@special
543 \ifcat\noexpand#1\relax % test if it's a command
545 \let\guji@whatcmd=#1%
546 \let\guji@iterate@next\guji@docommand
548 \testbreak\guji@oktext\guji@lasttext{#1}%
549 \ifx\guji@oktext\empty
551 %\message{oktext \meaning\guji@oktext}%
552 \setbox\guji@tmpbox=\hbox{\guji@oktext\hskip\guji@hanzisep}%
553 \guji@tmpdim=\wd\guji@tmpbox
554 \advance\guji@tmpdim by \guji@hoffset
555 \ifdim\guji@tmpdim > \guji@hsize % a break is required
557 \guji@hoffset=\wd\guji@tmpbox
560 \advance\guji@hoffset by \wd\guji@tmpbox
566 \expandafter\expandafter\expandafter\guji@iterate@next
572 \edef\guji@oktext{\guji@lasttext}%
573 \def\guji@lasttext{}%
574 \ifx\guji@oktext\empty
576 \setbox\guji@tmpbox=\hbox{\guji@oktext\hskip\guji@hanzisep}%
577 \guji@tmpdim=\wd\guji@tmpbox
578 \advance\guji@tmpdim by \guji@hoffset
579 \ifdim\guji@tmpdim > \guji@hsize % a break is required
581 \guji@hoffset=\wd\guji@tmpbox
584 \advance\guji@hoffset by \wd\guji@tmpbox
587 %\showbox\guji@tmpbox