5 \NeedsTeXFormat{LaTeX2e}
6 \ProvidesPackage{lltjp-listings}[2015/01/07 Patch to listings for LuaTeX-ja]
7 \RequirePackage{listings,luatexbase-cctb}
9 %%%%%%%%%%%%%%%% Japanese support
11 \newif\if@ltj@lst@vsraw \@ltj@lst@vsrawfalse
13 \lst@Key{vsraw}f[t]{\lstKV@SetIf{#1}\if@ltj@lst@vsraw}
14 \lst@Key{vscmd}\relax{\def\ltj@lst@vscmd{#1}}
17 \def\ltjlistingsvsstdcmd#1{\@tempdima=\f@size pt%
18 \smash{\raisebox{.35\@tempdima}{\tt%
19 \fboxsep=.1\@tempdima\fbox{\fontsize{.5\@tempdima}{\z@}\selectfont
20 \oalign{\hss VS\hss\crcr\hss#1\hss\crcr}}}}}
21 \def\ltj@lst@vscmd{\ltjlistingsvsstdcmd}
23 % override \lst@FillFixed@
24 % \ltj@hst@hss is \ltj@lst@hss@ivs or \ltj@lst@hss@normal,
25 % according to vsraw = true or not.
26 \def\lst@FillFixed@#1{%
27 \ifx\@empty#1\else\ltj@lst@hss#1\expandafter\lst@FillFixed@\fi}
30 local cat_str = luatexbase.catcodetables['string']
31 local cat_lp = luatexbase.catcodetables['latex-package']
32 local ubyte = unicode.utf8.byte
34 function luatexja.lst.althss(t)
36 if not (t>=0xE0100 and t<0xE01F0) then
37 tex.sprint(cat_lp, string.char(0x5C) .. 'lst@hss')
41 \gdef\ltj@lst@hss@ivs#1{%
42 \directlua{luatexja.lst.althss('\luatexluaescapestring{#1}')}#1%
46 \newif\if@ltj@lst@kanji
47 \lst@AddToHook{InitVars}{\@ltj@lst@kanjifalse}
49 \def\lst@AppendLetter{%
50 \ltj@lst@setletterflag\lst@Append}
51 \def\lst@AppendOther{%
52 \lst@ifletter\lst@Output\lst@letterfalse\fi\@ltj@lst@kanjifalse
53 \futurelet\lst@lastother\lst@Append}
55 \def\ltj@lst@setletterflag{%
57 \if@ltj@lst@kanji\lst@Output\@ltj@lst@kanjifalse\fi
59 \lst@lettertrue\if@ltj@lst@kanji\@ltj@lst@kanjifalse\else\lst@OutputOther\fi
62 \def\ltj@lst@setkanjiflag{%
66 \if@ltj@lst@kanji\else\lst@OutputOther\fi\lst@lettertrue
69 \def\ltj@lst@setopenflag{%
71 \lst@letterfalse\lst@Output
73 \if@ltj@lst@kanji\else\lst@OutputOther\fi
74 \fi\@ltj@lst@kanjitrue}
76 \def\ltj@lst@setcloseflag{%
77 \lst@ifletter\else\lst@lettertrue\fi\@ltj@lst@kanjitrue}
79 % Processing Japanese characters
80 \def\ltj@lst@ProcessJALetter#1{%
82 \ifnum\ltjgetparameter{jacharrange}{\ltjgetparameter{chartorange}{`#1}}=0
83 \ifnum\ltjgetparameter{postbreakpenalty}{`#1}>0
84 \ltj@lst@setopenflag % 開き括弧類
86 \ifnum\ltjgetparameter{prebreakpenalty}{`#1}>0
87 \ltj@lst@setcloseflag % 閉じ括弧類,句読点
89 \ltj@lst@setkanjiflag % 通常の和文文字
91 \advance\lst@length\@ne % 和文文字は通常の2倍の幅
93 \ltj@lst@setletterflag
98 \def\ltj@lst@ProcessJALetterHalf#1{%
100 \ifnum\ltjgetparameter{jacharrange}{\ltjgetparameter{chartorange}{`#1}}=0
101 \ifnum\ltjgetparameter{postbreakpenalty}{`#1}>0
102 \ltj@lst@setopenflag % 開き括弧類
104 \ifnum\ltjgetparameter{prebreakpenalty}{`#1}>0
105 \ltj@lst@setcloseflag % 閉じ括弧類
107 \ltj@lst@setkanjiflag % 通常の和文文字
111 \ltj@lst@setletterflag
116 \def\ltj@lst@ProcessIVS#1{%
119 \lst@Append#1\advance\lst@length\m@ne
121 \lst@TrackNewLines\lst@OutputLostSpace \lst@PrintToken
122 \setbox\@tempboxa\hbox to 2\lst@width{\hss
123 \expandafter\expandafter\expandafter\ltj@lst@vscmd
124 \expandafter{\the\numexpr`#1-"E00EF\relax}%"
126 \lst@CalcLostSpaceAndOutput\lst@whitespacefalse
131 \def\ltj@lst@ProcessVS#1{%
134 \lst@Append#1\advance\lst@length\m@ne
136 \lst@TrackNewLines\lst@OutputLostSpace \lst@PrintToken
137 \setbox\@tempboxa\hbox to 2\lst@width{\hss
138 \expandafter\expandafter\expandafter\ltj@lst@vscmd
139 \expandafter{\the\numexpr`#1-"FDFF\relax}%"
141 \lst@CalcLostSpaceAndOutput\lst@whitespacefalse
146 % 半角カナ,異体字セレクタはアクティブ化
147 \def\ltj@@listing@jpsetN#1#2#3{% for (not large) range
148 \@tempcnta=\numexpr#1-1\relax\@tempcntb=\numexpr 1+#2\relax
149 \loop \global\advance\@tempcnta\@ne\ifnum\@tempcnta<\@tempcntb\relax
150 \ltj@@listing@jpsetN@{\@tempcnta}{#3}\repeat
153 \def\ltj@@listing@jpsetN@#1#2{{%
154 \@tempcnta=#1 \lccode`\~=\@tempcnta \lccode`\/=\@tempcnta
155 \lowercase{\gdef\@temp{\gdef~{#2/}}}}%
156 \@temptokena\expandafter\expandafter\expandafter\expandafter%
157 \expandafter\expandafter\expandafter{\expandafter\expandafter%
158 \expandafter\the\expandafter\@temptokena\@temp}%
161 \ltj@@listing@jpsetN{65377}{65439}{\ltj@lst@ProcessJALetterHalf}
162 \ltj@@listing@jpsetN{65024}{65039}{\ltj@lst@ProcessVS}
163 \ltj@@listing@jpsetN{917760}{917999}{\ltj@lst@ProcessIVS}
164 \xdef\ltj@@listing@jpcmd{\the\@temptokena}\@temptokena{}
167 \newluatexcatcodetable\CatcodeTableLTJlistings
168 \setluatexcatcodetable\CatcodeTableLTJlistings{%
169 \luatexcatcodetable\CatcodeTableLaTeXAtLetter
171 \SetCatcodeRange{"FF61}{"FF9F}{13}% 半角カナ
172 \SetCatcodeRange{"E0100}{"E01EF}{13}% 漢字用異体字セレクタ
173 \SetCatcodeRange{"FE00}{"FE0F}{13}% Variation Selector
176 % redefine \lstinline@ and \lst@InlineG
177 % because \lstinline!あ...! causes ``Runaway argument?'' Error
180 \ltj@lst@check@inline{\lst@InlineM#1}{\lst@InlineJ#1}}
183 \ltj@lst@check@inline{\lst@InlineM\}}%
184 {\let\lst@arg\@empty \lst@InlineGJ}}
186 \def\ltj@lst@check@inline#1#2#3{%
187 \begingroup \lccode`\~=`#3\lowercase{\endgroup
190 \else\ifnum`#3>127\relax
196 % We redefine \lst@BeginDropInput, since now we have
197 % two additional `process macros'.
198 \def\lst@BeginDropInput#1{%
201 \let\lst@OutputBox\@gobble
202 \let\lst@ifdropinput\iftrue
203 \let\lst@ProcessLetter\@gobble
204 \let\lst@ProcessDigit\@gobble
205 \let\lst@ProcessOther\@gobble
206 \let\lst@ProcessSpace\@empty
207 \let\lst@ProcessTabulator\@empty
208 \let\lst@ProcessFormFeed\@empty
209 \let\ltj@lst@ProcessJALetter\@gobble % added
210 \let\ltj@lst@ProcessJALetterHalf\@gobble % added
215 \lst@AddToHook{Init}{%
216 \luatexcatcodetable\CatcodeTableLTJlistings\ltj@@listing@jpcmd
217 \lccode`\~="FFFFF\lowercase{\def~{\ltj@lst@ProcessJALetter}}%"
218 \directlua{luatexbase.add_to_callback('process_input_buffer',
221 for i = 1, utf.len(buf) do
222 local c = utf.sub(buf, i, i)
223 local cu = utf.byte(c)
224 if cu > 0x80 and tex.getcatcode(cu) \string~= 13 then
225 ret = ret .. utf.char(1048575) % U+FFFFF
230 end, 'ltj.listings_unicode', 1)}%
232 \let\ltj@lst@hss=\ltj@lst@hss@ivs
234 \let\ltj@lst@hss=\lst@hss
237 \lst@AddToHook{ExitVars}{%
238 \directlua{luatexbase.remove_from_callback('process_input_buffer',
239 'ltj.listings_unicode')}%
244 \def\lst@OutputToken{%
245 \lst@TrackNewLines \lst@OutputLostSpace
247 \lst@gobbledwhitespacefalse
251 {\lst@thestyle{\lst@FontAdjust
252 \setbox\@tempboxa\lst@hbox
255 \expandafter\lst@FillOutputBox\the\lst@token\@empty
257 \ht\@tempboxa=0pt\dp\@tempboxa=0pt
258 \lst@CalcLostSpaceAndOutput}}%
261 %%%%%%%%%%%%%%%% escape to \LaTeX
262 \lstloadaspects{escape}
263 \gdef\lst@Escape#1#2#3#4{%
264 \lst@CArgX #1\relax\lst@CDefX
266 {\lst@ifdropinput\else
267 \lst@TrackNewLines\lst@OutputLostSpace \lst@XPrintToken
269 \lst@EnterMode{\lst@TeXmode}{\lst@modetrue}%
271 \lst@CArg #2\relax\lst@ActiveCDefX
273 {\lst@escapeend #4\lst@LeaveAllModes\lst@ReenterModes}%
274 {\lst@MProcessListing}%
276 \lst@CArg #2\relax\lst@ActiveCDefX
278 {\lst@escapeend #4\lst@LeaveAllModes\lst@ReenterModes
279 \lst@newlines\z@ \lst@whitespacefalse}%
282 #3\catcode"FFFFF=9\lst@escapebegin%"
287 \lstloadaspects{writefile}
288 \begingroup \catcode`\^^I=11
289 \gdef\lst@WFBegin#1#2{%
291 \let\lst@OutputBox#1%
293 \advance\lst@length\@ne
294 \expandafter\lst@token\expandafter{\the\lst@token##1}%
295 \ifx ##1\lst@outputspace \else
298 \lst@lAddTo\lst@PreGotoTabStop{\lst@WFAppend{^^I}}%
299 \lst@lAddTo\lst@ProcessSpace{\lst@WFAppend{ }}%
300 \def\ltj@lst@ProcessIVS##1{\lst@whitespacefalse\lst@Append##1}%
301 \def\ltj@lst@ProcessVS##1{\lst@whitespacefalse\lst@Append##1}%
302 \let\lst@DeInit\lst@WFDeInit
303 \let\lst@MProcessListing\lst@WFMProcessListing
305 \immediate\openout\lst@WF=#2\relax
306 \global\let\lst@WFifopen\iftrue
312 % \begin{修正事項}{1.3} from jlisting.sty
314 \gdef\lst@breakProcessOther#1{\lst@ProcessOther#1}
315 % ソースコード目次における文字と番号の空き
316 \let \l@lstlisting = \l@figure
317 % キャプションとソースコード目次に対する日本語対応
318 \def\lstlistingname{ソースコード}
319 \def\lstlistlistingname{ソースコード目次}