Patch of llmk for LaTeX Workshop
LaTeX Workshop ではさまざまなタイプセット方法が許容されているが,llmk によるタイプセットでは問題が生じる.これは以下の記事に詳しい.
LaTeX Workshopでllmkしてみたらアレだった件 - マクロツイーター
この問題点は,相互参照の問題を解決するための複数回のタイプセットによって生じる警告をすべて拾ってしまうということである.
上の記事内ではLaTeX Workshop 内のコードをいじって解決させていたが,拡張機能のコードをいじるのには抵抗がある.
llmk にBatch を当ててこれを解決させようと思う.
解決方法は以下の通り.
llmk でのビルドログをhoge.llmk.log ファイルに記載
ログファイルから最後のllmk info: Running command:
より下をtype
要は,最後にトリガーされたLaTeX だけを出力してあげれば,これだけをLaTeX Workshop が読むので,それまでの警告は無視されて警告に関する問題は解決するということになる.はず.
作成したBatch は次のファイルに.ファイル名は"Patch of llmk for LaTeX Workshop" から"patchllmk4lw.bat" とした.
Windows10
LaTeX Workshop ver. 8.19.2
llmk ver. 0.2.0
注意
: llmk の更新次第によってはこのパッチが利用できなくなる可能性があります.
Batch ファイルを適当なディレクトリに配置してsettings.json にtool とrecipe を追加する.
以下ではX:\path\to\batch
に設置した.
"latex-workshop.latex.recipes" : [
{
"name" : " llmk: Build with Batch" ,
"tools" : [
" llmk-batch"
],
},
],
"latex-workshop.latex.tools" : [
{
"name" : " llmk-batch" ,
"command" : " X:\\ path\\ to\\ batch\\ patchllmk4lw.bat" ,
"args" : [
" %DOC%"
],
},
],
あとはいつもの通りにLaTeX を作成してllmk: Build with Batch
すれば良い.
以下のようなLaTeX ドキュメントをタイプセットしたい.シンプルにbib ファイルだけを含むドキュメント.
% +++++
% llmk_version = 0.2.0
% sequence = [ "latex", "bibtex", "latex" ]
% +++++
\documentclass [11pt,a4paper ]{jlreq }
\usepackage {luatexja }
\usepackage {hyperref }
\begin {document }
\section {\LaTeX {} Workshop で\textsf {llmk} する }\label {ref-section }
Batch でパッチを当てれば\LaTeX {} Workshop でもマトモに\textsf {llmk}\cite {asakura2020Light } 出来る.\ref {ref-section }
\bibliography {test.bib}
\bibliographystyle {plain}
\end {document }
@misc {asakura2020Light ,
author = { Takuto Asakura} ,
title = { {Light} {\LaTeX} {Make} - \textsf{llmk}: {A} build tool for {\LaTeX} documents} ,
howpublished = { \url{https://ctan.org/pkg/light-latex-make}} ,
year = { 2020}
}
成功例と失敗例を紹介しておきたい.
Success PDF Image
Output パネルのLaTeX Compiler に以下のような出力を得る.
LaTeX Compiler at Output Panel (折りたたみ)
警告が含まれる場合,ここにwarning
などが記載される.これをLaTeX Workshop が拾ってProblem パネルに表示させている.
----- ----- ----- -----
llmk info: Running command: lualatex -interaction=nonstopmode -file-line-error -synctex=1 "d:/patch/latex/workshop/llmk/test.tex"
This is LuaHBTeX, Version 1.13.1 (TeX Live 2021/W32TeX)
restricted system commands enabled.
(d:/patch/latex/workshop/llmk/test.tex
LaTeX2e <2020-10-01> patch level 4
L3 programming layer <2021-02-18> (d:/texlive/2021/texmf-dist/tex/latex/jlreq/jlreq.cls
Document Class: jlreq 2021/03/17 jlreq
(d:/texlive/2021/texmf-dist/tex/latex/xkeyval/xkeyval.sty (d:/texlive/2021/texmf-dist/tex/generic/xkeyval/xkeyval.tex (d:/texlive/2021/texmf-dist/tex/generic/xkeyval/xkvutils.tex (d:/texlive/2021/texmf-dist/tex/generic/xkeyval/keyval.tex)))) (d:/texlive/2021/texmf-dist/tex/latex/everyhook/everyhook.sty (d:/texlive/2021/texmf-dist/tex/latex/svn-prov/svn-prov.sty) (d:/texlive/2021/texmf-dist/tex/latex/etoolbox/etoolbox.sty)) (d:/texlive/2021/texmf-dist/tex/latex/base/ifthen.sty) (d:/texlive/2021/texmf-dist/tex/latex/jlreq/jlreq-helpers.sty) jlreq guessed engine: lualatex (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/luatexja.sty (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/luatexja-core.sty (d:/texlive/2021/texmf-dist/tex/luatex/luatexbase/luatexbase.sty (d:/texlive/2021/texmf-dist/tex/luatex/ctablestack/ctablestack.sty)) (d:/texlive/2021/texmf-dist/tex/generic/ltxcmds/ltxcmds.sty) (d:/texlive/2021/texmf-dist/tex/generic/pdftexcmds/pdftexcmds.sty (d:/texlive/2021/texmf-dist/tex/generic/infwarerr/infwarerr.sty) (d:/texlive/2021/texmf-dist/tex/generic/iftex/iftex.sty)) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/ltj-base.sty) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/ltj-latex.sty (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/patches/lltjfont.sty (d:/texlive/2021/texmf-dist/tex/latex/base/tuenc.def) (d:/texlive/2021/texmf-dist/tex/latex/everysel/everysel.sty (d:/texlive/2021/texmf-dist/tex/latex/everysel/everysel-2011-10-28.sty)) ABD: EverySelectfont initializing macros) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/patches/lltjdefs.sty
(d:/texlive/2021/texmf-dist/tex/luatex/jlreq/jfm-jlreqv.lua)
(d:/texlive/2021/texmf-dist/tex/luatex/jlreq/jfm-jlreq.lua)) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/patches/lltjcore.sty (d:/texlive/2021/texmf-dist/tex/latex/l3kernel/expl3.sty (d:/texlive/2021/texmf-dist/tex/latex/l3backend/l3backend-luatex.def))) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/patches/lltjp-atbegshi.sty) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/patches/lltjp-geometry.sty (d:/texlive/2021/texmf-dist/tex/generic/iftex/ifluatex.sty)))) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/luatexja-compat.sty)) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/addons/luatexja-adjust.sty) (d:/texlive/2021/texmf-dist/tex/latex/lm/lmodern.sty)) (d:/texlive/2021/texmf-dist/tex/latex/hyperref/hyperref.sty (d:/texlive/2021/texmf-dist/tex/generic/kvsetkeys/kvsetkeys.sty) (d:/texlive/2021/texmf-dist/tex/generic/kvdefinekeys/kvdefinekeys.sty) (d:/texlive/2021/texmf-dist/tex/generic/pdfescape/pdfescape.sty) (d:/texlive/2021/texmf-dist/tex/latex/hycolor/hycolor.sty) (d:/texlive/2021/texmf-dist/tex/latex/letltxmacro/letltxmacro.sty) (d:/texlive/2021/texmf-dist/tex/latex/auxhook/auxhook.sty) (d:/texlive/2021/texmf-dist/tex/latex/kvoptions/kvoptions.sty) (d:/texlive/2021/texmf-dist/tex/latex/hyperref/pd1enc.def) (d:/texlive/2021/texmf-dist/tex/latex/hyperref/hyperref-langpatches.def) (d:/texlive/2021/texmf-dist/tex/generic/intcalc/intcalc.sty) (d:/texlive/2021/texmf-dist/tex/generic/etexcmds/etexcmds.sty) (d:/texlive/2021/texmf-dist/tex/latex/hyperref/puenc.def) (d:/texlive/2021/texmf-dist/tex/latex/url/url.sty) (d:/texlive/2021/texmf-dist/tex/generic/bitset/bitset.sty (d:/texlive/2021/texmf-dist/tex/generic/bigintcalc/bigintcalc.sty)) (d:/texlive/2021/texmf-dist/tex/latex/base/atbegshi-ltx.sty)) (d:/texlive/2021/texmf-dist/tex/latex/hyperref/hluatex.def (d:/texlive/2021/texmf-dist/tex/generic/stringenc/stringenc.sty) (d:/texlive/2021/texmf-dist/tex/latex/base/atveryend-ltx.sty) (d:/texlive/2021/texmf-dist/tex/latex/rerunfilecheck/rerunfilecheck.sty (d:/texlive/2021/texmf-dist/tex/generic/uniquecounter/uniquecounter.sty))) (./test.aux) (d:/texlive/2021/texmf-dist/tex/latex/base/ts1cmr.fd) ABD: EverySelectfont initializing macros (d:/texlive/2021/texmf-dist/tex/latex/hyperref/nameref.sty (d:/texlive/2021/texmf-dist/tex/latex/refcount/refcount.sty) (d:/texlive/2021/texmf-dist/tex/generic/gettitlestring/gettitlestring.sty)) (./test.out) (./test.out) (d:/texlive/2021/texmf-dist/tex/latex/lm/ot1lmr.fd) (d:/texlive/2021/texmf-dist/tex/latex/lm/omllmm.fd) (d:/texlive/2021/texmf-dist/tex/latex/lm/omslmsy.fd) (d:/texlive/2021/texmf-dist/tex/latex/lm/omxlmex.fd) (./test.bbl) [1{d:/texlive/2021/texmf-var/fonts/map/pdftex/updmap/pdftex.map}] (./test.aux))
2141 words of node memory still in use:
8 hlist, 1 vlist, 5 rule, 2 glue, 7 kern, 2 glyph, 684 attribute, 73 glue_spec, 38 attribute_list, 1 write, 17 user_defined, 1 pdf_action nodes
avail lists: 1:10,2:8746,3:123,4:102,5:108,6:20,7:874,8:43,9:193,10:2,11:12
<d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmroman10-regular.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmmono12-regular.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmroman8-regular.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmsans12-regular.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/haranoaji/HaranoAjiMincho-Regular.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmroman12-regular.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/haranoaji/HaranoAjiGothic-Medium.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmsans10-bold.otf>
Output written on test.pdf (1 page, 25849 bytes).
SyncTeX written on test.synctex.gz.
Transcript written on test.log.
llmk info: Success (Errorlevel: 0)
----- ----- ----- ----- -----
このときのProblem パネルでは何も表示されていない.
また,実行後のディレクトリは以下のようになった.Batch によってtest.llmk.log が作成されている.
D:\patch\latex\workshop\llmk> dir \s\b
D:\patch\latex\workshop\llmk\test.aux
D:\patch\latex\workshop\llmk\test.bbl
D:\patch\latex\workshop\llmk\test.bib
D:\patch\latex\workshop\llmk\test.blg
D:\patch\latex\workshop\llmk\test.llmk.log
D:\patch\latex\workshop\llmk\test.log
D:\patch\latex\workshop\llmk\test.out
D:\patch\latex\workshop\llmk\test.pdf
D:\patch\latex\workshop\llmk\test.synctex.gz
D:\patch\latex\workshop\llmk\test.tex
また,test.llmk.log ファイルを確認するとllmk によって自動的に以下のコマンドが実行されていることが分かる.
lualatex → bibtex → lualatex → lualatex
以下のように,\ref
や\cite
で間違いがあるとしてみたい.
% +++++
% llmk_version = 0.2.0
% sequence = [ "latex", "bibtex", "latex" ]
% +++++
\documentclass [11pt,a4paper ]{jlreq }
\usepackage {luatexja }
\usepackage {hyperref }
\begin {document }
\section {\LaTeX {} Workshop で\textsf {llmk} する }\label {ref-section }
Batch でパッチを当てれば\LaTeX {} Workshop でもマトモに\textsf {llmk}\cite {asakura2020Light_fail } 出来る.\ref {ref-section_fail }
\bibliography {test.bib}
\bibliographystyle {plain}
\end {document }
Failed PDF Image
LaTeX Compiler at Output Panel (折りたたみ)
----- ----- ----- -----
llmk info: Running command: lualatex -interaction=nonstopmode -file-line-error -synctex=1 "d:/patch/latex/workshop/llmk/test.tex"
This is LuaHBTeX, Version 1.13.1 (TeX Live 2021/W32TeX)
restricted system commands enabled.
(d:/patch/latex/workshop/llmk/test.tex
LaTeX2e <2020-10-01> patch level 4
L3 programming layer <2021-02-18> (d:/texlive/2021/texmf-dist/tex/latex/jlreq/jlreq.cls
Document Class: jlreq 2021/03/17 jlreq
(d:/texlive/2021/texmf-dist/tex/latex/xkeyval/xkeyval.sty (d:/texlive/2021/texmf-dist/tex/generic/xkeyval/xkeyval.tex (d:/texlive/2021/texmf-dist/tex/generic/xkeyval/xkvutils.tex (d:/texlive/2021/texmf-dist/tex/generic/xkeyval/keyval.tex)))) (d:/texlive/2021/texmf-dist/tex/latex/everyhook/everyhook.sty (d:/texlive/2021/texmf-dist/tex/latex/svn-prov/svn-prov.sty) (d:/texlive/2021/texmf-dist/tex/latex/etoolbox/etoolbox.sty)) (d:/texlive/2021/texmf-dist/tex/latex/base/ifthen.sty) (d:/texlive/2021/texmf-dist/tex/latex/jlreq/jlreq-helpers.sty) jlreq guessed engine: lualatex (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/luatexja.sty (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/luatexja-core.sty (d:/texlive/2021/texmf-dist/tex/luatex/luatexbase/luatexbase.sty (d:/texlive/2021/texmf-dist/tex/luatex/ctablestack/ctablestack.sty)) (d:/texlive/2021/texmf-dist/tex/generic/ltxcmds/ltxcmds.sty) (d:/texlive/2021/texmf-dist/tex/generic/pdftexcmds/pdftexcmds.sty (d:/texlive/2021/texmf-dist/tex/generic/infwarerr/infwarerr.sty) (d:/texlive/2021/texmf-dist/tex/generic/iftex/iftex.sty)) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/ltj-base.sty) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/ltj-latex.sty (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/patches/lltjfont.sty (d:/texlive/2021/texmf-dist/tex/latex/base/tuenc.def) (d:/texlive/2021/texmf-dist/tex/latex/everysel/everysel.sty (d:/texlive/2021/texmf-dist/tex/latex/everysel/everysel-2011-10-28.sty)) ABD: EverySelectfont initializing macros) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/patches/lltjdefs.sty
(d:/texlive/2021/texmf-dist/tex/luatex/jlreq/jfm-jlreqv.lua)
(d:/texlive/2021/texmf-dist/tex/luatex/jlreq/jfm-jlreq.lua)) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/patches/lltjcore.sty (d:/texlive/2021/texmf-dist/tex/latex/l3kernel/expl3.sty (d:/texlive/2021/texmf-dist/tex/latex/l3backend/l3backend-luatex.def))) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/patches/lltjp-atbegshi.sty) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/patches/lltjp-geometry.sty (d:/texlive/2021/texmf-dist/tex/generic/iftex/ifluatex.sty)))) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/luatexja-compat.sty)) (d:/texlive/2021/texmf-dist/tex/luatex/luatexja/addons/luatexja-adjust.sty) (d:/texlive/2021/texmf-dist/tex/latex/lm/lmodern.sty)) (d:/texlive/2021/texmf-dist/tex/latex/hyperref/hyperref.sty (d:/texlive/2021/texmf-dist/tex/generic/kvsetkeys/kvsetkeys.sty) (d:/texlive/2021/texmf-dist/tex/generic/kvdefinekeys/kvdefinekeys.sty) (d:/texlive/2021/texmf-dist/tex/generic/pdfescape/pdfescape.sty) (d:/texlive/2021/texmf-dist/tex/latex/hycolor/hycolor.sty) (d:/texlive/2021/texmf-dist/tex/latex/letltxmacro/letltxmacro.sty) (d:/texlive/2021/texmf-dist/tex/latex/auxhook/auxhook.sty) (d:/texlive/2021/texmf-dist/tex/latex/kvoptions/kvoptions.sty) (d:/texlive/2021/texmf-dist/tex/latex/hyperref/pd1enc.def) (d:/texlive/2021/texmf-dist/tex/latex/hyperref/hyperref-langpatches.def) (d:/texlive/2021/texmf-dist/tex/generic/intcalc/intcalc.sty) (d:/texlive/2021/texmf-dist/tex/generic/etexcmds/etexcmds.sty) (d:/texlive/2021/texmf-dist/tex/latex/hyperref/puenc.def) (d:/texlive/2021/texmf-dist/tex/latex/url/url.sty) (d:/texlive/2021/texmf-dist/tex/generic/bitset/bitset.sty (d:/texlive/2021/texmf-dist/tex/generic/bigintcalc/bigintcalc.sty)) (d:/texlive/2021/texmf-dist/tex/latex/base/atbegshi-ltx.sty)) (d:/texlive/2021/texmf-dist/tex/latex/hyperref/hluatex.def (d:/texlive/2021/texmf-dist/tex/generic/stringenc/stringenc.sty) (d:/texlive/2021/texmf-dist/tex/latex/base/atveryend-ltx.sty) (d:/texlive/2021/texmf-dist/tex/latex/rerunfilecheck/rerunfilecheck.sty (d:/texlive/2021/texmf-dist/tex/generic/uniquecounter/uniquecounter.sty))) (./test.aux) (d:/texlive/2021/texmf-dist/tex/latex/base/ts1cmr.fd) ABD: EverySelectfont initializing macros (d:/texlive/2021/texmf-dist/tex/latex/hyperref/nameref.sty (d:/texlive/2021/texmf-dist/tex/latex/refcount/refcount.sty) (d:/texlive/2021/texmf-dist/tex/generic/gettitlestring/gettitlestring.sty)) (./test.out) (./test.out) (d:/texlive/2021/texmf-dist/tex/latex/lm/ot1lmr.fd) (d:/texlive/2021/texmf-dist/tex/latex/lm/omllmm.fd) (d:/texlive/2021/texmf-dist/tex/latex/lm/omslmsy.fd) (d:/texlive/2021/texmf-dist/tex/latex/lm/omxlmex.fd)
LaTeX Warning: Citation `asakura2020Light_fail' on page 1 undefined on input line 11.
LaTeX Warning: Reference `ref-section_fail' on page 1 undefined on input line 11.
(./test.bbl
LaTeX Warning: Empty `thebibliography' environment on input line 3.
) [1{d:/texlive/2021/texmf-var/fonts/map/pdftex/updmap/pdftex.map}] (./test.aux)
LaTeX Warning: There were undefined references.
)
1929 words of node memory still in use:
8 hlist, 1 vlist, 5 rule, 2 glue, 5 kern, 2 glyph, 607 attribute, 67 glue_spec, 34 attribute_list, 1 write, 16 user_defined nodes
avail lists: 1:10,2:5047,3:84,4:84,5:75,6:15,7:427,8:9,9:169,11:6
<d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmroman10-regular.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmroman12-bold.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmsans12-regular.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmroman8-regular.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/haranoaji/HaranoAjiMincho-Regular.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmroman12-regular.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/haranoaji/HaranoAjiGothic-Medium.otf><d:/texlive/2021/texmf-dist/fonts/opentype/public/lm/lmsans10-bold.otf>
Output written on test.pdf (1 page, 21974 bytes).
SyncTeX written on test.synctex.gz.
Transcript written on test.log.
llmk info: Success (Errorlevel: 0)
----- ----- ----- ----- -----
LaTeX に警告が含まれていてもllmk はSuccess 判定になっているようだ.
警告は以下のように出力される.期待していた通り,重複するメッセージは出力されていない.
もちろん,この出力ではPDF 上の相互参照は??
となっている.
llmk では--verbose
オプションを有効にするとllmk info: Running command:
に続いてLaTeX コマンドが引数付きで記載される.
今回,これをマーカーにして最後のタイプセットを判定している.
ただし,--verbose
を含めてログファイルを作成しようとするとllmk info: Running command:
の箇所はログファイルに記載されなくなる.
これを記載させるためには標準エラーを含めるように2>&1
すれば良い.
おそらくこのような解決法でllmk の相互参照の警告に関する問題は解決していると思われる.
利用していて不具合が発見されたら改善していきたい.それまでにはLaTeX Workshop がllmk に対応していてくれるだろう……
作成したBatch ファイルはLaTeX Workshop 外でも利用できる.また,カレントディレクトリから実行する場合であれば指定するTeX ファイルはフルパスである必要はないです.
$ X:\path\to\batch\patchllmk4lw.bat hoge.tex
MIT License の下で公開しているので自由に使ってください.
また,「もっと良いコードの書き方があるだろ!」と思われる方がいれば好きに改変してください.
適当にコメントアウトでコードの作成意図を示しておきました.
それにしてもファイル名がダサいよなぁ.