Emacs上でLaTeXを編集するときに便利なパッケージの一つとしてAUCTeXが知られている。本記事は設定と使い方を備忘録として残すのが主旨である。
TeXのインストール
TeX Wikiを参考にするとよい。Emacs上で執筆するならばscheme-small (BasicTeX)とcollection-langjapaneseをインストールするのが良いだろう。
AUCTeXのインストール
M-x package-install RET auctex RET
とするか、もしくは
M-x list-packages RET
からauctexを選択する。
設定
Emacsの設定
日本語文章の執筆を前提とする。またPDFビューワーにはpdf-toolsを使用していることに注意。使用するビューワーは各自の好みで選択し、その設定を変えることができる。
latexmkの設定
もしlatexmk
を利用する場合は、.latexmkrcを設定して~/.latexmkrcなどに保存したうえで実行するのが良い。以下の.latexmkrcはdviを経由するタイプである。
uplatex
を用いる場合は以下の設定を参考に。
#!/usr/bin/env perl $latex = "uplatex -halt-on-error -interaction=nonstopmode -file-line-error %O %S"; $bibtex = 'upbibtex %O %S'; $biber = 'biber --bblencoding=utf8 -u -U --output_safechars %O %S'; $makeindex = 'mendex %O -o %D %S'; $dvipdf = 'dvipdfmx %O -o %D %S'; $pdf_mode = 3; $max_repeat = 5;
platex
を用いる場合は以下の設定を参考に。
#!/usr/bin/env perl $latex = "platex -kanji=utf8 -halt-on-error -interaction=nonstopmode -file-line-error %O %S"; $bibtex = 'pbibtex -kanji=utf8 %O %S'; $biber = 'biber --bblencoding=utf8 -u -U --output_safechars %O %S'; $makeindex = 'mendex %O -o %D %S'; $dvipdf = 'dvipdfmx %O -o %D %S'; $pdf_mode = 3; $max_repeat = 5;
もしtexから直接pdfを生成する場合の設定例は以下。$pdf_modeを1にすることが重要である。
#!/usr/bin/env perl # texからpdfを直接生成 (pdflatex) $pdf_mode = 1; $bibtex = 'upbibtex %O %S'; $makeindex = 'umendex %O -o %D %S'; $pdf_previewer = "evince %S"; $max_repeat = 5;
ただし日本語文章でpdflatex
を通す場合はBXjscls パッケージなどを併用するとよい。
\documentclass[pdflatex, ja=standard]{bxjsarticle} %ほかはa4paperなどがオプションに入る
設定の参考にしたサイト
解説と補足
AUCTeXの設定の情報源
AUCTeX Wikiに多くの情報が集約されており、まずはここに書いてある設定を参考にしながら自身の設定ファイルに追記していくのがよい。
使い方
コンパイルからPDF表示まで
AUCTeX Wikiを参考に、よく使うものをテーブルにリストする。
- コマンド起動
入力 | 機能 |
---|---|
C-c C-c |
コマンドの選択メニューを表示(処理対象範囲:文書全体) |
C-c C-r |
コマンドの選択メニューを表示(処理対象範囲:リージョン) |
C-c C-b |
コマンドの選択メニューを表示(処理対象範囲:カレントバッファ) |
C-c C-c
の「文書全体」とは、例えばファイル分割している場合にそれらをすべて取り込む形を指す。C-c C-b
はカレントバッファ(=現在編集中のバッファ)のみが処理対象となる。
- コマンド例(
C-c C-c
の場合)
メニュー | 入力例 | 機能 |
---|---|---|
LaTeX | C-c C-c latex |
指定された TeX エンジン (TeX-engine)でタイプセット |
BibTeX | C-c C-c bibtex |
bibtex の実行(文献データベースの更新) |
Dvipdfmx | C-c C-c dvipdfmx |
dvipdfmx の実行 |
View | C-c C-c view |
プレビュー |
Clean | C-c C-c clean |
中間ファイル (.log .aux etc...) の削除 |
Clean All | C-c C-c clean all |
中間ファイル及び dvi ps pdf の削除 |
上記はC-c C-c
経由でコマンドを発動した場合の例である。個々のコマンドの機能はC-c C-r
やC-c C-b
でも同じである。
- その他
入力 | 機能 |
---|---|
C-c C-v |
プレビューの起動(Viewのショートカット起動) |
C-c C-a |
タイプセット、(文献DB更新、)dvipdfmx、プレビューを順に実行 |
C-c C-l |
タイプセット処理を表示 |
基本となるのは
1. "LaTeX"によりタイプセット(コンパイル)→texソースからpdfファイルを生成
2. "View"によりpdfを開く
という処理の流れである。 これを使う場合,texソースに\usepackage[pdftex]{graphicx}
を書いておくべし。
dviを経由する場合,代わりに\usepackage[dvipdfmx]{graphicx}
をtexソースに記入し、
(setq TeX-PDF-from-DVI "Dvipdfmx")
の設定を追記しておく。処理の流れは以下の通り。
1. "LaTeX"によりタイプセット(コンパイル)→texソースからdviファイルを生成
2. "Dvipdfmx"によりdviからpdfを生成
3. "View"によりpdfを開く
文章中で参考文献を引用している場合は1と2の間にBibTeXが入る。
1. "LaTeX"によりタイプセット
2. "BiBTeX"により文献データベースを更新 →bibファイルからbblファイルを生成
3. "LaTeX"によりもう一度タイプセット →texソースからdviファイルを生成
4. "Dvipdfmx"によりdviからpdfを生成
5. "View"によりpdfを開く
編集中に便利なキーバインドとスニペット
以下は多用するキーバインドである。
入力 | 機能 |
---|---|
C-c C-e |
LaTeX環境(\begin{...} \end{....})を選択的に挿入 |
C-c C-s |
セクション関係(\section{}や\subsection)を選択的に挿入 |
C-c ] |
LaTeX環境を閉じる(\end{...} をのみ挿入) |
C-c ; |
リージョンをコメントアウト |
C-c % |
カーソル最寄りの段落をコメントアウト |
C-c * |
カーソルに最寄りのセクション関係をマーク |
C-c . |
カーソルに最寄りのLaTeX環境をマーク |
yasnippetユーザならば、多くのスニペットがLaTeX用に提供されるので、使ってみるとよい。上記のキーバインドがあれば十分かもしれないが、どちらも便利なので併用している。
latexmkについて
latexmkを用いて PDF をコマンド一つで生成するという主旨の記事がある。同記事では"auctex-latexmk"というパッケージが件の機能を提供するものとして紹介されている。本記事で紹介している設定ではauctex-latexmk関連をコメントアウトしてある。利用はお好みで。
日本語対応のエンジンの例としてLuaTeX-jaが知られている。LuaTeX-jaを用いるとpdflatexでなくともtexからpdfを直接生成できるので便利に使える。ほか、LuaTeXを用いるメリットとして、フォント周りの設定がしやすいことが挙げられる。詳細は別の記事で紹介する予定である。
latexmkを保存と同時に走らせる場合は以下の記事で紹介した設定を追記する。
インラインプレビューについて
AUCTeXでは数式や画像のインラインプレビューが可能である。対象となる数式はpng画像に変換されてEmacs上でプレビューされる。以下は主なキーバインドである。C-c C-p
(pはpreviewの意味)から始まるので比較的覚えやすい。
入力 | 機能 |
---|---|
C-c C-p C-d |
マスタ文書のプレビュー開始 |
C-c C-p C-c C-d |
文書全体のプレビュー終了 |
C-c C-p C-b |
カレントバッファのプレビュー開始 |
C-c C-p C-c C-b |
カレントバッファのプレビュー終了 |
C-c C-p C-p |
ポイント位置のプレビュー開始 |
C-c C-p C-c C-p |
ポイント位置のプレビュー終了 |
C-c C-p C-e |
LaTeX環境で囲まれた部分のプレビュー開始 |
C-c C-p C-c C-e |
LaTeX環境で囲まれた部分のプレビュー終了 |
C-c C-p C-s |
セクションのプレビュー開始 |
C-c C-p C-c C-s |
セクションのプレビュー終了 |