OSDN Git Service

6ad407c304412e0da2a0ef32d8180fcc67b5f88b
[luatex-ja/luatexja.git] / src / luatexja-core.sty
1 % LuaTeX-ja core TeX source
2
3 \catcode`\@=11
4 \catcode"FFFFF=14 %"
5
6 \input luaotfload.sty
7 \input ltxcmds.sty
8 \input xkeyval.tex
9 \input infwarerr.sty
10 \ifdefined\ltj@loaded\endinput\fi
11 \def\ltj@loaded{hoge}
12
13 \newcount\ltj@tempcnta
14 \newcount\ltj@tempcntb
15 \newcount\ltj@tempcntc
16 \newdimen\ltj@tempdima
17
18
19 \newcount\jcharwidowpenalty
20 \newskip\kanjiskip
21 \newskip\xkanjiskip
22 \newdimen\zw
23 \newdimen\zh
24 \newdimen\jQ \jQ=0.25mm
25 \newdimen\jH \jH=0.25mm
26
27 %%%%%%%% Attributes for Japanese typesetting.
28 \newluatexattribute\ltj@curjfnt   % index for ``current Japanese font''
29 \newluatexattribute\ltj@charclass % 
30 \newluatexattribute\ltj@yablshift % attribute for \yabaselineshift
31 \newluatexattribute\ltj@ykblshift % attribute for \ykbaselineshift
32 \newluatexattribute\ltj@autospc   % attribute for autospacing
33 \newluatexattribute\ltj@autoxspc  % attribute for autoxspacing
34 \newluatexattribute\ltj@icflag    % attribute for italic correction
35 \newlanguage\ltj@japanese
36
37 %%%%%%%% Loading lua files
38 \directlua{%
39   utf = unicode.utf8
40   ltj = {}
41   function ltj.loadlua(file)
42     local path = assert(kpse.find_file(file, 'tex'),
43       "File '"..file.."' not found")
44     texio.write_nl("("..path..")")
45     dofile(path)
46   end
47   require('lualibs')
48   ltj.loadlua('luatexja-rmlgbm.lua') 
49     % For Ryumin-Light and GothicBBB-Medium.
50   ltj.loadlua('luatexja-jfont.lua')
51   ltj.loadlua('luatexja-core.lua')
52   ltj.loadlua('luatexja-jfmglue.lua')
53   ltj.loadlua('luatexja-xkanji.lua')
54 }
55
56
57 %%%%%%%% Attributes for character ranges
58 \ltj@tempcnta=0
59 \loop\ifnum\ltj@tempcnta<7
60   \expandafter\newluatexattribute%
61     \csname ltj@kcat\the\ltj@tempcnta\endcsname
62   \csname ltj@kcat\the\ltj@tempcnta\endcsname=0
63   \advance\ltj@tempcnta by1
64 \repeat
65
66 %%%%%%%% \asluastring
67 \def\asluastring#1{'\luaescapestring{\detokenize{#1}}'}
68
69 %%%%%%%% Redefine \/
70 %\let\ltj@ic=\/ \protected\def\/{{\ltj@icflag=1\ltj@ic}}
71 \protected\def\/{\directlua{ltj.ext_append_italic()}}
72
73 %%%%%%%% \jfont\CS={...:...;jfm=metric;...}, \globaljfont
74 \protected\def\jfont{\afterassignment\ltj@@jfont\directlua{ltj.ext_jfontdefX(false)}}
75 \protected\def\globaljfont{%
76   \afterassignment\ltj@@jfont\directlua{ltj.ext_jfontdefX(true)}}
77 \def\ltj@@jfont{\directlua{ltj.ext_jfontdefY()}}
78
79 %%%%%%%% \inhibitglue
80 \protected\def\inhibitglue{\directlua{ltj.ext_create_inhibitglue_node()}}
81
82 %%%%%%%% \ltjdefcharrange<name>{100-200,3000-,5000,...}
83 \protected\def\ltjdefcharrange#1#2{%
84   \ltj@tempcntc=#1 \expandafter\ltj@@dcrange#2,,\ignorespaces}
85 \def\ltj@@dcrange#1,{\def\ltj@temp{#1}%
86   \ifx\ltj@temp\empty\let\@next=\relax\else
87   \ltj@@dcrangeA{#1}\let\@next=\ltj@@dcrange\fi\@next}
88 \def\ltj@@dcrangeA#1{\ltj@@dcrangeB#1--\@nil}
89 \def\ltj@@dcrangeB#1-#2-#3\@nil{\def\ltj@temp{#3}%
90   \ifx\ltj@temp\empty
91     \ltj@tempcnta=#1 \ltj@tempcntb=\ltj@tempcnta
92   \else
93     \def\ltj@temp{#1}%
94     \ifx\ltj@temp\empty\ltj@tempcnta='200 \else\ltj@tempcnta=#1 \fi
95     \def\ltj@temp{#2}%
96     \ifx\ltj@temp\empty\ltj@tempcntb="10FFFF \else\ltj@tempcntb=#2 \fi%"
97   \fi
98   \directlua{ltj.ext_add_char_range(\the\ltj@tempcnta,\the\ltj@tempcntb,
99     \the\ltj@tempcntc)}%
100   }
101
102 %%%%%%%% \ltjsetparameter
103 \newcount\ltj@@stack \newcount\ltj@@group@level
104 \ltj@@group@level=0 \ltj@@stack=0
105
106 % prebreakpenalty = {<char_code>, <penalty>}
107 \define@key[ltj]{japaram}{kcatcode}{%
108   \expandafter\ltj@@set@stack#1:{kcat}{0}{0x7FFFFFFF}}
109 \define@key[ltj]{japaram}{prebreakpenalty}{%
110   \expandafter\ltj@@set@stack#1:{pre}{-10000}{10000}}
111 \define@key[ltj]{japaram}{postbreakpenalty}{%
112   \expandafter\ltj@@set@stack#1:{post}{-10000}{10000}}
113 \def\ltj@@set@stack#1,#2:#3#4#5{%
114   \ltj@tempcnta=#1\relax \ltj@tempcntb=#2\relax
115   \directlua{ltj.ext_set_stack_table(ltj.isglobal, \asluastring{#3},
116     \the\ltj@tempcnta,tex.getcount('ltj@tempcntb'),#4,#5)}}
117
118 % yalbaselineshift = <dimen>
119 % yjabaselineshift = <dimen>
120 \define@key[ltj]{japaram}{yalbaselineshift}{%
121   \ltj@tempdima=#1\relax%
122   \directlua{tex.setattribute(ltj.isglobal, 
123     luatexbase.attributes['ltj@yablshift'],
124     tex.getdimen('ltj@tempdima'))}}
125 \define@key[ltj]{japaram}{yjabaselineshift}{%
126   \ltj@tempdima=#1\relax%
127   \directlua{tex.setattribute(ltj.isglobal, 
128     luatexbase.attributes['ltj@ykblshift'],
129     tex.getdimen('ltj@tempdima'))}}
130
131 % jaxspmode = {<char_code>, <mode>}
132 % mode: inhibit, preonly, postonly, allow
133 %    or       0        2         1      3
134 \define@key[ltj]{japaram}{jaxspmode}{%        \inhibitxspcode
135   \expandafter\ltj@set@jaxspmode#1:\relax}
136 \def\ltj@set@jaxspmode#1,#2:{%
137   \lowercase{\edef\ltj@temp{#2}}%
138   \def\ltj@tempa{inhibit}\ifx\ltj@temp\ltj@tempa\def\ltj@temp{0}\fi
139   \def\ltj@tempa{preonly}\ifx\ltj@temp\ltj@tempa\def\ltj@temp{2}\fi
140   \def\ltj@tempa{postonly}\ifx\ltj@temp\ltj@tempa\def\ltj@temp{1}\fi
141   \def\ltj@tempa{allow}\ifx\ltj@temp\ltj@tempa\def\ltj@temp{3}\fi
142   \ltj@tempcnta=#1\relax\ltj@tempcntb=\ltj@temp\relax
143   \directlua{ltj.ext_set_stack_table(ltj.isglobal, 'xsp', \the\ltj@tempcnta,
144     \the\ltj@tempcntb,0,3)}}
145
146 % alxspmode = {<char_code>, <mode>}
147 % mode: inhibit, preonly, postonly, allow
148 %    or       0        1         2      3
149 \define@key[ltj]{japaram}{alxspmode}{%        \inhibitxspcode
150   \expandafter\ltj@set@alxspmode#1:\relax}
151 \def\ltj@set@alxspmode#1,#2:{%
152   \lowercase{\edef\ltj@temp{#2}}%
153   \def\ltj@tempa{inhibit}\ifx\ltj@temp\ltj@tempa\def\ltj@temp{0}\fi
154   \def\ltj@tempa{preonly}\ifx\ltj@temp\ltj@tempa\def\ltj@temp{1}\fi
155   \def\ltj@tempa{postonly}\ifx\ltj@temp\ltj@tempa\def\ltj@temp{2}\fi
156   \def\ltj@tempa{allow}\ifx\ltj@temp\ltj@tempa\def\ltj@temp{3}\fi
157   \ltj@tempcnta=#1\relax\ltj@tempcntb=\ltj@temp\relax
158   \directlua{ltj.ext_set_stack_table(ltj.isglobal, 'xsp', \the\ltj@tempcnta,
159     \the\ltj@tempcntb,0,3)}}
160
161 % autospacing = <bool> (default: true)
162 \define@boolkey[ltj]{japaram}{autospacing}[true]{%
163   \ifltj@japaram@autospacing
164     \directlua{ltj.ext_print_global()}\ltj@autospc=1
165   \else
166     \directlua{ltj.ext_print_global()}\ltj@autospc=0
167   \fi}
168
169 % autoxspacing = <bool> (default: true)
170 \define@boolkey[ltj]{japaram}{autoxspacing}[true]{%
171   \ifltj@japaram@autoxspacing
172     \directlua{ltj.ext_print_global()}\ltj@autoxspc=1
173   \else
174     \directlua{ltj.ext_print_global()}\ltj@autoxspc=0
175   \fi}
176
177 \define@key[ltj]{japaram}{kanjiskip}{%              % SKIP
178   \directlua{ltj.ext_print_global()}\kanjiskip=#1 }
179 \define@key[ltj]{japaram}{xkanjiskip}{%             % SKIP
180   \directlua{ltj.ext_print_global()}\xkanjiskip=#1 }
181 \define@key[ltj]{japaram}{jcharwidowpenalty}{%      %COUNT
182   \directlua{ltj.ext_print_global()}\jcharwidowpenalty=#1 }
183
184 % differentjfm = { large | small | average | both }
185 \define@choicekey*+[ltj]{japaram}{differentjfm}[\ltj@temp\ltj@tempr]%
186   {large,small,average,both}{%
187   \ifcase\ltj@tempr
188     \directlua{ltj.ja_diffmet_rule = math.max}\or
189     \directlua{ltj.ja_diffmet_rule = math.min}\or
190     \directlua{ltj.ja_diffmet_rule = math.two_average}\or
191     \directlua{ltj.ja_diffmet_rule = math.two_add}
192   \fi
193 }{\@PackageWarning{luatexja}{ignored invalid argument '#1' for 'differentjfm'}}
194   % large, small, average, both
195
196
197 % jacharrange = { +-<range_number> }
198 \define@key[ltj]{japaram}{jacharrange}{\expandafter\ltj@@scrange#1,,}
199 \def\ltj@@scrange#1,{%
200   \edef\ltj@temp{#1}%
201   \ifx\ltj@temp\empty\let\next=\relax\else\let\next=\ltj@@scrange
202     \ltj@tempcnta=#1 \directlua{ltj.ext_toggle_char_range(%
203       ltj.is_global,\the\ltj@tempcnta)}%
204   \fi\next
205 }
206
207 \protected\def\ltjsetparameter#1{\directlua{ltj.isglobal=''}%
208   \setkeys[ltj]{japaram}{#1}\ignorespaces}
209 \protected\def\ltjglobalsetparameter#1{\directlua{ltj.isglobal='global'}%
210   \setkeys[ltj]{japaram}{#1}\ignorespaces}
211
212 %%%%%%%% 
213 \def\ltj@@decl@array@param#1{%
214   \expandafter\let\csname ltj@@array@param/#1\endcsname=t%
215 }
216 \ltj@@decl@array@param{prebreakpenalty}
217 \ltj@@decl@array@param{postbreakpenalty}
218 \ltj@@decl@array@param{jaxspmode}
219 \ltj@@decl@array@param{alxspmode}
220 \ltj@@decl@array@param{kcatcode}
221 \ltj@@decl@array@param{jacharrange}
222 \ltj@@decl@array@param{chartorange}
223 \def\ltjgetparameter#1{%
224   \ifcsname ltj@@array@param/#1\endcsname
225     \expandafter\ltx@firstoftwo
226   \else
227     \expandafter\ltx@secondoftwo
228   \fi
229   {\ltj@@getparam@two{#1}}%
230   {\ltj@@getparam@one{#1}}%
231 }
232 \def\ltj@@getparam@one#1{%
233   \directlua{ltj.ext_get_parameter_unary('#1')}}%
234 \def\ltj@@getparam@two#1#2{\ltj@tempcnta=#2
235   \directlua{ltj.ext_get_parameter_binary('#1', \the\ltj@tempcnta)}%
236 }
237
238
239
240 \def\ltj@temp{plain}
241 \ifx\fmtname\ltj@temp
242   \message{plain format: loading luatexja-plain.tex}
243 \fi
244 \input luatexja-plain.tex
245 \catcode`\@=12
246 \endinput