yatex

annotate docs/yatexj.tex @ 84:73cba5ddd111

Converted from RCS of yatex
author yuuji
date Sun, 27 Sep 2009 13:04:14 +0000
parents 0734be649cb8
children e1693ffc64cc
rev   line source
yuuji@73 1 \def\lang{jp} % -*- texinfo -*- for Texinfo V.3.1
yuuji@73 2 \input texinfo
yuuji@73 3 @setfilename yatexj
yuuji@73 4 @settitle Yet Another tex-mode for Emacs
yuuji@73 5
yuuji@73 6 @iftex
yuuji@73 7 @c @syncodeindex fn cp
yuuji@73 8 @c いつも忘れるのでここに書いとくか。
yuuji@73 9 @c C-l C-c n でノード入れ
yuuji@73 10 @c ノードいじったら C-l C-u C-n 全部のノード更新 C-l C-u C-e
yuuji@73 11 @c メニュー増やしたら C-l C-u C-m 全部のメニュー更新 C-l C-u C-a
yuuji@73 12 @c フォーマットするときは C-l C-e C-b
yuuji@80 13 @c Last modified Wed Jul 20 21:25:48 2005 on firestorm
yuuji@73 14 @syncodeindex vr cp
yuuji@73 15 @end iftex
yuuji@73 16
yuuji@73 17 @titlepage
yuuji@73 18 @sp 10
yuuji@73 19 @center
yuuji@73 20 @subtitle Yet Another tex-mode for emacs
yuuji@73 21 @title 『野鳥』
yuuji@73 22 @subtitle // YaTeX //
yuuji@80 23 @author @copyright{} 1991-2004 by HIROSE, Yuuji [yuuji@@yatex.org]
yuuji@73 24 @end titlepage
yuuji@73 25
yuuji@73 26 @node Top, Intro, (dir), (dir)
yuuji@73 27 @comment node-name, next, previous, up
yuuji@73 28
yuuji@73 29 @menu
yuuji@73 30 * Intro:: はじめに
yuuji@73 31 * Terminology:: マニュアル参照上の注意
yuuji@73 32 * Main features:: 主な機能
yuuji@73 33 * Installation:: インストール
yuuji@73 34 * Invocation:: プロセス起動
yuuji@73 35 * %#notation :: %#記法
yuuji@73 36 * Completion:: 補完入力
yuuji@73 37 * Local dictionary:: ローカル辞書
yuuji@73 38 * Commenting out:: コメントアウト
yuuji@73 39 * Cursor jump:: カーソルジャンプ
yuuji@73 40 * Modifying/Deleting:: LaTeXコマンドの変更/削除
yuuji@73 41 * Filling:: 桁揃え
yuuji@73 42 * Includeonly:: 勝手に includeonly
yuuji@73 43 * What column:: カラム位置ガイド
yuuji@73 44 * Intelligent newline:: おまかせ改行
yuuji@79 45 * Usepackage cheker:: 先回りusepackage
yuuji@73 46 * Changing mode of YaTeX:: 野鳥動作モード変更
yuuji@73 47 * Online help:: LaTeXオンラインヘルプ
yuuji@73 48 * Inclusion hierarchy browser:: ファイル分割階層構造の表示
yuuji@73 49 * Cooperation with other packages:: 他パッケージとの連携
yuuji@73 50 * Customizations:: カスタマイズ
yuuji@73 51 * Etc:: その他
yuuji@73 52 * Copying:: 取り扱い
yuuji@73 53 * Concept Index:: 索引
yuuji@73 54
yuuji@73 55 @end menu
yuuji@73 56
yuuji@73 57 @node Intro, Terminology, Top, Top
yuuji@73 58 @comment node-name, next, previous, up
yuuji@73 59 @chapter はじめに
yuuji@73 60 @cindex Demacs
yuuji@73 61 @cindex Mule
yuuji@73 62 @cindex LaTeX
yuuji@73 63 @cindex やちょう[やちよう]
yuuji@73 64
yuuji@73 65 野鳥は、GNU Emacs で La@TeX{} 用の文書を作成する時に pLa@TeX{} などの
yuuji@73 66 タイプセットコマンドや、プレヴューアの起動を Emacs 編集画面中から
yuuji@73 67 行えるようにすると共に、拡張性の高い種々の補完機能によりソーステキ
yuuji@73 68 ストの編集を支援します。さらに La@TeX{} コマンドのオンラインヘルプに
yuuji@73 69 よりマニュアルを調べる手間を軽減します。
yuuji@73 70
yuuji@73 71 English manual @xref{Top, , , yatexe,YaTeX English info}.
yuuji@73 72
yuuji@73 73 @node Terminology, Main features, Intro, Top
yuuji@73 74 @comment node-name, next, previous, up
yuuji@73 75 @chapter 本マニュアル参照上の注意
yuuji@73 76
yuuji@73 77 本マニュアルでは以下の表記を用います。
yuuji@73 78
yuuji@73 79 @itemize @bullet
yuuji@73 80 @item
yuuji@73 81 begin型コマンド
yuuji@73 82
yuuji@73 83 @code{\begin@{環境@} 〜 \end@{環境@}}という形式のLaTeXコマンドを指します。
yuuji@73 84 begin型コマンドを補完入力することをbegin型補完と呼びます。
yuuji@73 85
yuuji@73 86 @item
yuuji@73 87 section型コマンド
yuuji@73 88
yuuji@73 89 @code{\section@{タイトル@}}や@code{\mbox@{内容@}}のように
yuuji@73 90 引数を取るLaTeXコマンドを指します。
yuuji@73 91
yuuji@73 92 @item
yuuji@73 93 maketitle型コマンド
yuuji@73 94
yuuji@73 95 @code{\maketitle}や@code{\tableofcontents}のように引数を取らないLaTeXコマ
yuuji@73 96 ンドを指します。
yuuji@73 97
yuuji@73 98 @item
yuuji@73 99 large型コマンド
yuuji@73 100
yuuji@73 101 @code{@{\large ...@}} や @code{@{\tt ...@}} のようなフォント/サイズ指定子
yuuji@73 102 を指します。
yuuji@73 103
yuuji@73 104 @item @kbd{[prefix]}
yuuji@73 105
yuuji@73 106 野鳥の機能を呼び出すためのプリフィクスキー。デフォルトでは@kbd{C-c}に割り
yuuji@73 107 当てられているので、特に変更していない場合本マニュアルの @kbd{[prefix]} と
yuuji@73 108 いう表記は、@kbd{C-c} と読み換えてください。
yuuji@73 109 @end itemize
yuuji@73 110
yuuji@73 111 @node Main features, Installation, Terminology, Top
yuuji@73 112 @comment node-name, next, previous, up
yuuji@73 113 @chapter 主な機能
yuuji@73 114
yuuji@73 115 @itemize @bullet
yuuji@73 116 @item タイプセッタやプレヴューアなどの編集画面からの起動(@kbd{C-c t})
yuuji@73 117 @item カーソル位置によらない固定リジョンの部分タイプセット
yuuji@73 118 @item \includeonlyのワンタッチ更新
yuuji@73 119 @item エラー箇所への自動ジャンプ(@kbd{C-c '})
yuuji@73 120 @item @code{\begin@{@}, \end@{@}, \section...} などの La@TeX{}
yuuji@73 121 コマンドの補完入力
yuuji@73 122 (@kbd{C-c b}, @kbd{C-c s}, @kbd{C-c l}, @kbd{C-c m})
yuuji@73 123 @item 既に入力したテキストを環境やコマンド引数の中に取り込む括り補完
yuuji@73 124 (@kbd{C-u} +通常補完キー)
yuuji@73 125 @item セクション区切り入力時の文書構造アウトライン表示
yuuji@73 126 @item セクションコマンドの一括シフト (@ref{view-sectioning})
yuuji@73 127 @item 補完辞書の学習
yuuji@73 128 @item La@TeX{} の環境やコマンドに応じたガイド付き引数入力
yuuji@73 129 @item 野鳥にないガイド付き引数入力関数の自動生成(@file{yatexgen.el})
yuuji@73 130 @item La@TeX{} コマンドの削除/変更(@kbd{C-c k}, @kbd{C-c c})
yuuji@73 131 @item ファイル間、@code{\begin}<->@code{\end}間、
yuuji@73 132 @code{\ref}<->@code{\label}間、
yuuji@73 133 @code{\cite}<->@code{\bibitem}ジャンプ(@kbd{C-c g})
yuuji@73 134 @item 一括コメントアウト/アンコメントアウト
yuuji@73 135 (@kbd{C-c >}, @kbd{C-c <}, @kbd{C-c ,}, @kbd{C-c .})
yuuji@73 136 @item アクセント記号/数式環境用コマンド/ギリシャ文字の入力支援
yuuji@73 137 (@kbd{C-c a}, @kbd{;}, @kbd{/})
yuuji@73 138 @item tabular/array環境のカラム位置ガイド
yuuji@73 139 @item 標準的 La@TeX{} コマンドのオンラインヘルプ(@kbd{C-c ?}, @kbd{C-c /})
yuuji@73 140 @item ドキュメントのインクルード構造の視覚的表示とバッファ切り替え
yuuji@73 141 (@kbd{C-c d})
yuuji@80 142 @item 補完入力したマクロに応じて必要な \userpackage を入れてくれる先回り
yuuji@80 143 userpackage
yuuji@80 144 @item \labelを打つことはもう忘れよう! refやcite補完入力で自動生成します
yuuji@73 145 @end itemize
yuuji@73 146
yuuji@73 147 @node Installation, Invocation, Main features, Top
yuuji@73 148 @comment node-name, next, previous, up
yuuji@73 149 @chapter 起動法
yuuji@73 150 @cindex Install
yuuji@73 151 @cindex インストール[いんすとおる]
yuuji@73 152 @cindex .emacs
yuuji@73 153 @cindex auto-mode-alist
yuuji@73 154 @cindex autoload
yuuji@73 155 @section 野鳥起動のための設定
yuuji@73 156
yuuji@73 157 ~/.emacsに下の2項目を加えます。
yuuji@73 158
yuuji@73 159 @lisp
yuuji@73 160 (setq auto-mode-alist
yuuji@73 161 (cons (cons "\\.tex$" 'yatex-mode) auto-mode-alist))
yuuji@73 162 (autoload 'yatex-mode "yatex" "Yet Another LaTeX mode" t)
yuuji@73 163 @end lisp
yuuji@73 164
yuuji@73 165 次に野鳥の emacs-lisp ファイル群を置くディレクトリを load-path に加えます。
yuuji@73 166 たとえば、 @file{~/src/emacs/yatex}に置くのであれば、
yuuji@73 167
yuuji@73 168 @lisp
yuuji@73 169 (setq load-path (cons (expand-file-name "~/src/emacs/yatex") load-path))
yuuji@73 170 @end lisp
yuuji@73 171
yuuji@73 172 @noindent
yuuji@73 173 などとします。
yuuji@73 174
yuuji@73 175 以上の設定により、拡張子が .tex であるファイルを編集すると自動的に野鳥が
yuuji@73 176 ロードされます。野鳥が正常に起動できたときはモードラインの表示が「やてふ」
yuuji@73 177 に変わります。
yuuji@73 178
yuuji@73 179 @section タイプセッタ/プレヴューア環境の設定
yuuji@73 180
yuuji@73 181 利用する外部プログラムに関する以下の変数を確認し、必要なら正しい値に変更
yuuji@73 182 します。
yuuji@73 183 @table @code
yuuji@73 184 @item tex-command
yuuji@73 185 @dots{} 起動するタイプセッタのコマンド名
yuuji@73 186 @item dvi2-command
yuuji@73 187 @dots{} 起動するプレヴューアのコマンド名
yuuji@73 188 @item NTT-jTeX
yuuji@73 189 @dots{} 改行+インデントによって、タイプセット後の字間が空いてしま
yuuji@73 190 うのを抑制する場合にtにする(古いNTT-jTeXで顕著に現れる)。具体的には、
yuuji@73 191 fillするときに各行の終わりに%を付加するようになる。
yuuji@73 192 @item YaTeX-kanji-code
yuuji@73 193 @dots{} 文書を作成する時の漢字コード
yuuji@73 194 @item dviprint-command-format
yuuji@73 195 @dots{} ファイルの印刷に使われるコマンド列の書式
yuuji@73 196 @item makeindex-command
yuuji@73 197 @dots{} makeindexコマンド
yuuji@73 198 @end table
yuuji@73 199
yuuji@73 200 これらを変更する場合は、やはり@file{~/.emacs}にて、たとえば
yuuji@73 201 @lisp
yuuji@73 202 (setq tex-command "bigjlatex")
yuuji@73 203 @end lisp
yuuji@73 204 のようにしてください。どのような値をセットすれば良いかについては、
yuuji@73 205 @ref{All customizable variables}を参照してください。
yuuji@73 206
yuuji@73 207
yuuji@73 208 @node Invocation, %#notation , Installation, Top
yuuji@73 209 @comment node-name, next, previous, up
yuuji@73 210 @chapter latexコマンド起動
yuuji@73 211 @cindex prefix key
yuuji@73 212 @cindex C-c
yuuji@73 213 @cindex タイプセッタ[たいふせつた]
yuuji@73 214 @cindex プレヴューア[ふれひゆうあ]
yuuji@73 215 @cindex jlatex
yuuji@73 216 @cindex platex
yuuji@73 217 @cindex プリントアウト[ふりんとあうと]
yuuji@73 218
yuuji@73 219 LaTeXソースの編集中、次のキー入力により、platex などのタイプセットプログラ
yuuji@73 220 ム(以後タイプセッタと呼ぶ)、プレヴューアなどの起動ができます。
yuuji@73 221
yuuji@73 222 @table @kbd
yuuji@73 223 @item [prefix] t j
yuuji@73 224 @dots{} タイプセッタ(platex)起動
yuuji@73 225 @item [prefix] t r
yuuji@73 226 @dots{} タイプセッタ起動(領域指定)
yuuji@73 227 @item [prefix] t k
yuuji@73 228 @dots{} 動作中のタイプセッタの停止
yuuji@73 229 @item [prefix] t b
yuuji@73 230 @dots{} jbibtex起動
yuuji@73 231 @item [prefix] t p
yuuji@73 232 @dots{} プレヴューア起動
yuuji@73 233 @item [prefix] t l
yuuji@73 234 @dots{} lpr(プリントアウト用)コマンド起動
yuuji@73 235 @item [prefix] t s
yuuji@73 236 @dots{} xdvi -remote でのサーチ
yuuji@73 237 @end table
yuuji@73 238
yuuji@73 239 @menu
yuuji@73 240 * Calling typesetter:: タイプセッタ起動
yuuji@73 241 * Calling previewer:: プレヴューア起動
yuuji@73 242 * Print out:: プリントアウト用コマンドの起動
yuuji@73 243 @end menu
yuuji@73 244
yuuji@73 245 @node Calling typesetter, Calling previewer, Invocation, Invocation
yuuji@73 246 @comment node-name, next, previous, up
yuuji@73 247 @section タイプセッタ起動
yuuji@73 248 @cindex タイプセッタ起動[たいふせつたきとう]
yuuji@73 249 @cindex タイプセットエラー[たいふせつとえらあ]
yuuji@73 250 @cindex エラー修正[えらあしゆうせい]
yuuji@73 251
yuuji@73 252 タイプセッタを起動すると、編集ウィンドウが2つに分割され、片方のウィンド
yuuji@73 253 ウにタイプセット画面が表示されます。出力されるメッセージと連動しタイプセッ
yuuji@73 254 トバッファは自動的にスクロールします。もし、途中でエラーが起こって止まって
yuuji@73 255 しまった場合にはタイプセットバッファに移り、(@kbd{C-x o}) タイプセッタの出
yuuji@73 256 している ? プロンプトに対して、@kbd{x} (処理の中断)などの指示を送ることが
yuuji@73 257 できます。エラーを修正する場合は、
yuuji@73 258
yuuji@73 259 @table @kbd
yuuji@73 260 @item [prefix] '
yuuji@73 261 @itemx (prefix+アポストロフィ)
yuuji@73 262 @dots{} 直前のエラー発生行へジャンプ
yuuji@73 263 @end table
yuuji@73 264
yuuji@73 265 を入力することにより、タイプセッタがエラーを発生した行に移ることができます。
yuuji@73 266 また、タイプセッタの出力する overfull hbox などのウォーニング行にも対応し
yuuji@73 267 ていますので、順次 @kbd{[prefix] '} を押すことにより、一つ前のウォーニング
yuuji@73 268 発生行にジャンプしていきます。
yuuji@73 269
yuuji@73 270 もし、気になるエラー行があった場合は、タイプセットバッファで、エ
yuuji@73 271 ラーの表示されている行にカーソルを合わせスペースキーを押すと La@TeX{}
yuuji@73 272 ソースの対応する行にジャンプします。
yuuji@73 273
yuuji@73 274 @subsection 領域タイプセット
yuuji@73 275
yuuji@73 276 ポイントとマークの間、あるいはテキスト中に埋め込んだ @code{%#BEGIN} と
yuuji@73 277 @code{%#END}の間の領域(@ref{%#notation})だけを切り取ってタイプセットすることが
yuuji@73 278 できます。この場合の documentclass は、単一ファイルの La@TeX{} ソースの編
yuuji@73 279 集時にはそのファイルの documentclass が、別ファイルから include している場
yuuji@73 280 合にはメインファイルの documentclass が自動的に選択されます。指定領域は、
yuuji@73 281 メインファイルのあるディレクトリの@file{texput.tex}という臨時ファイルに出
yuuji@73 282 力されますので、上書きには注意してください。
yuuji@73 283
yuuji@73 284 @node Calling previewer, Print out, Calling typesetter, Invocation
yuuji@73 285 @comment node-name, next, previous, up
yuuji@73 286 @section プレヴューア起動
yuuji@73 287 @kbd{[prefix] t p} によりプレヴューアの起動ができます。さらに、もしあな
yuuji@73 288 たが、-remote 機能つきのxdviを利用している場合は @kbd{[prefix] t s} を押す
yuuji@73 289 ことによりカーソル位置の文字列を検索してそのページを表示するようにすでに起
yuuji@73 290 動中のxdviに命令を送ります。これにより、現在編集中の箇所のタイプセット結果
yuuji@73 291 を即座に見ることができます。
yuuji@73 292
yuuji@73 293 @c なお、-remote 機能付きの xdvi は
yuuji@73 294 @c @code{ftp://ftp.ae.keio.ac.jp/pub/text/xdvi/xdvi-remote}
yuuji@73 295 @c などから入手することができます。
yuuji@73 296
yuuji@73 297 @node Print out, , Calling previewer, Invocation
yuuji@73 298 @comment node-name, next, previous, up
yuuji@73 299 @section プリントアウト
yuuji@73 300
yuuji@73 301 @kbd{[prefix] t l}を押してプリントアウトを指示すると、出力開始/終了ペー
yuuji@73 302 ジを聞いてくるので、それぞれに答えます。これを省略したい時は、
yuuji@73 303 universal-argument をつけ、
yuuji@73 304
yuuji@73 305 @cindex 出力開始ページ[しゆつりよくかいしへえし]
yuuji@73 306 @cindex 出力終了ページ[しゆつりよくしゆうりようへえし]
yuuji@73 307
yuuji@73 308 @table @kbd
yuuji@73 309 @item C-u [prefix] t l
yuuji@73 310 @dots{} ページ確認省略lpr起動
yuuji@73 311 @end table
yuuji@73 312 @cindex ページ確認省略lpr起動[へえしかくにんしようりやくlprきとう]
yuuji@73 313
yuuji@73 314 @noindent
yuuji@73 315 のように起動してください。
yuuji@73 316
yuuji@73 317 @node %#notation , Completion, Invocation, Top
yuuji@73 318 @comment node-name, next, previous, up
yuuji@73 319 @chapter %#記法
yuuji@73 320
yuuji@73 321 本文中に@code{%#}ではじまるキーワードを埋め込むことでタイプセッタ起動等
yuuji@73 322 の制御をすることができます。
yuuji@73 323
yuuji@73 324 @menu
yuuji@73 325 * Changing typesetter:: タイプセット用コマンドの変更
yuuji@73 326 * Splitting input files:: 入力ファイル分割
yuuji@73 327 * Fix region for typesetting:: 領域の固定
yuuji@73 328 * lpr format:: プリントアウトコマンド用フォーマット
yuuji@73 329 * Editing %# notation:: %#記法の編集
yuuji@73 330 @end menu
yuuji@73 331
yuuji@73 332 @node Changing typesetter, Splitting input files, %#notation , %#notation
yuuji@73 333 @comment node-name, next, previous, up
yuuji@73 334 @section タイプセット用コマンド変更
yuuji@73 335
yuuji@73 336 起動するコマンドを変えたい時は本文中に次のような行を書きます。
yuuji@73 337
yuuji@73 338 @cindex 起動するコマンドを変える[きとうするこまんとをかえる]
yuuji@73 339
yuuji@73 340 @example
yuuji@73 341 %#!jlatex-ntt
yuuji@73 342 @end example
yuuji@73 343
yuuji@73 344 NTT jTeX と、ASCII jTeX を使い分けたいような場合に便利でしょう。
yuuji@73 345
yuuji@73 346 @cindex タイプセッタの使い分け[たいふせつたのつかいわけ]
yuuji@73 347
yuuji@73 348 @node Splitting input files, Fix region for typesetting, Changing typesetter, %#notation
yuuji@73 349 @comment node-name, next, previous, up
yuuji@73 350 @section 入力ファイル分割
yuuji@73 351
yuuji@73 352 また、章毎に別ファイルの .tex を作成している場合で、@file{main.tex}から
yuuji@73 353 @file{sub.tex}を @code{\include}しているような時は、@file{sub.tex}の任意の
yuuji@73 354 位置に次のような行を埋め込みます。
yuuji@73 355
yuuji@73 356 @example
yuuji@73 357 %#!platex main.tex
yuuji@73 358 @end example
yuuji@73 359
yuuji@73 360 @cindex 入力ファイル分割[にゆうりよくふあいるふんかつ]
yuuji@73 361
yuuji@73 362 上の例のようにコマンド名だけでなく引数も書いた場合には、全てをそのまま
yuuji@73 363 shell に渡すので次のように書けば、ghostview などをプレヴューアに使う時に便
yuuji@73 364 利です。
yuuji@73 365
yuuji@73 366 @cindex ghostview
yuuji@73 367
yuuji@73 368 @example
yuuji@73 369 %#!platex main ; dvi2ps main.dvi > main
yuuji@73 370 @end example
yuuji@73 371
yuuji@73 372 なお、この行の最後の単語のピリオド以前を「メインファイル」のベース
yuuji@73 373 ネームであると仮定します(上の2つの場合どちらも@file{main})。
yuuji@80 374 この行に記述した、@code{%f}はメインファイル名に、
yuuji@80 375 @code{%r} はメインファイルの拡張子を取り除いた部分に置換されます。
yuuji@80 376 ただし、@code{%f,%r}を利用した場合、初回タイプセット時に必ずメインファイル
yuuji@80 377 名の入力を促されます。
yuuji@73 378
yuuji@73 379 @kbd{[prefix] g} (@ref{Cursor jump}参照) での
yuuji@73 380 ファイル間ジャンプを有効に機能させるため、入力ファイル分割時には次のことに
yuuji@73 381 注意して下さい。
yuuji@73 382
yuuji@73 383 @enumerate
yuuji@73 384 @item
yuuji@73 385 サブディレクトリを作って、その中にサブファイルを置くことはできるが
yuuji@73 386 サブディレクトリのサブディレクトリには置けない。
yuuji@73 387 @item
yuuji@73 388 メインファイルからサブディレクトリ内のファイルを include
yuuji@73 389 する時には、相対パス指定を用いて、
yuuji@73 390 @code{\include@{chap1/sub@}}のように記述。
yuuji@73 391 @item
yuuji@73 392 メインファイルが一つ上のディレクトリにある場合も、サブファイルには
yuuji@73 393 %#!platex main.tex のように記述する(../mainではない)。
yuuji@73 394 @end enumerate
yuuji@73 395
yuuji@73 396
yuuji@73 397
yuuji@73 398 @node Fix region for typesetting, lpr format, Splitting input files, %#notation
yuuji@73 399 @comment node-name, next, previous, up
yuuji@73 400 @section 領域の固定
yuuji@73 401 @cindex 固定領域のタイプセット[こていりよういきのたいふせつと]
yuuji@73 402 @cindex %#BEGIN
yuuji@73 403 @cindex %#END
yuuji@73 404
yuuji@73 405 @kbd{[prefix] tr} の領域指定のタイプセットでは、とくに指定のないかぎり、
yuuji@73 406 @kbd{C-SPC}でマークした位置と、ポイント(カーソル位置)の間を領域とみなしま
yuuji@73 407 すが、必ず決まった領域をタイプセットしたい場合は、その領域を
yuuji@73 408
yuuji@73 409 @example
yuuji@73 410 %#BEGIN
yuuji@73 411 <渡したい領域>
yuuji@73 412 %#END
yuuji@73 413 @end example
yuuji@73 414
yuuji@73 415 @noindent
yuuji@73 416 のように@code{%#BEGIN}と@code{%#END}で囲み、カーソルを「@code{%#BEGIN}以降」
yuuji@73 417 に置いてください。この時の領域決定規則をまとめると次のようになります。
yuuji@73 418
yuuji@73 419
yuuji@73 420 @enumerate
yuuji@73 421 @item
yuuji@73 422 カーソル位置よりバッファの先頭方向に@code{%#BEGIN}というキーワードが
yuuji@73 423 ある場合
yuuji@73 424
yuuji@73 425 @enumerate
yuuji@73 426 @item
yuuji@73 427 @code{%#BEGIN}よりバッファの末尾方向に@code{%#END}というキーワードが見つかっ
yuuji@73 428 た場合。
yuuji@73 429 @result{}@code{%#BEGIN} から、その @code{%#END} のある位置まで。
yuuji@73 430 @item
yuuji@73 431 @code{%#END} が見つからなかった場合。
yuuji@73 432 @result{}バッファの最後尾まで。
yuuji@73 433 @end enumerate
yuuji@73 434 @cindex 領域決定規則[りよういきけつていきそく]
yuuji@73 435
yuuji@73 436 @item
yuuji@73 437 カーソル位置よりバッファの先頭方向に @code{%#BEGIN} というキーワードが
yuuji@73 438 見つからなかった場合。
yuuji@73 439 @result{}マーク(@kbd{C-SPC}位置)とポイント(カーソル位置)の間の領域。
yuuji@73 440 @end enumerate
yuuji@73 441
yuuji@73 442 tabular 環境を何度も試行錯誤しているような場合は、@code{\begin}の前の行
yuuji@73 443 に @code{%#BEGIN} と書き、@code{\end} の次の行に @code{%#END} と書いておく
yuuji@73 444 と簡単に作表結果をテストすることができます。また、長い .tex ファイルの後半
yuuji@73 445 に @code{%#BEGIN} を書いておけば、前半の部分は無視できます。このBEGINとEND
yuuji@73 446 の消し忘れには十分ご注意下さい。
yuuji@73 447 @cindex 長いファイルの編集[なかいふあいるのへんしゆう]
yuuji@73 448
yuuji@73 449 @c @node Require, lpr format, Fix region for typesetting, %#notation
yuuji@73 450 @comment node-name, next, previous, up
yuuji@73 451
yuuji@73 452 @node lpr format, Editing %# notation, Fix region for typesetting, %#notation
yuuji@73 453 @comment node-name, next, previous, up
yuuji@73 454 @section lprフォーマット
yuuji@73 455 @cindex lprふぉーまっと[lprふおおまつと]
yuuji@73 456 @cindex lprフォーマット[lprふおおまつと]
yuuji@73 457 @cindex lpr format
yuuji@73 458
yuuji@73 459 まず、プリントアウト用コマンド列のフォーマットについて説明します。
yuuji@73 460 コマンド列フォーマットは、3つの Lisp 変数によって表現されます。デ
yuuji@73 461 フォルトの dvi2ps 用のフォーマットを例に説明します。
yuuji@73 462
yuuji@73 463 @table @code
yuuji@73 464 @item (1)dviprint-command-format
yuuji@73 465 @code{"dvi2ps %f %t %s | lpr"}
yuuji@73 466
yuuji@73 467 @item (2)dviprint-from-format
yuuji@73 468 @code{"-f %b"}
yuuji@73 469
yuuji@73 470 @item (3)dviprint-to-format
yuuji@73 471 @code{"-t %e"}
yuuji@73 472 @end table
yuuji@73 473
yuuji@73 474 実際にプリントアウトする時は、(1)中の %s がファイル名に置き換えられ、%f が
yuuji@73 475 (2)の内容、%t が(3)の内容に置き換えられます。その際に(2)の文字列中の %b は
yuuji@73 476 「出力開始ページ」、(3)の文字列中の %e は「出力終了ページ」に置き換えられ
yuuji@73 477 ます。もし、ページを指定しない時には、%f, %t 両方とも無視されます。
yuuji@73 478
yuuji@73 479 この、dviprint-command-format を臨時に変えたい時は、La@TeX{} の
yuuji@73 480 ソーステキスト中の任意の場所に、
yuuji@73 481
yuuji@73 482 @example
yuuji@73 483 %#LPR dvi2ps %f %t %s | 4up -page 4 | texfix | lpr -Plp2
yuuji@73 484 @end example
yuuji@73 485
yuuji@73 486 @noindent
yuuji@73 487 のように書いて下さい。プリントアウトするページ範囲をいちいち聞かせないよう
yuuji@73 488 にする時に
yuuji@73 489
yuuji@73 490 @example
yuuji@73 491 %#LPR dvi2ps %s | lpr
yuuji@73 492 @end example
yuuji@73 493
yuuji@73 494 @noindent
yuuji@73 495 などとするのも便利かもしれません。
yuuji@73 496
yuuji@73 497 @node Editing %# notation, , lpr format, %#notation
yuuji@73 498 @comment node-name, next, previous, up
yuuji@73 499 @section %#記法自体の編集
yuuji@73 500 @cindex %#記法自体の編集[%#きほうしたいのへんしゆう]
yuuji@73 501
yuuji@73 502 以上のような@code{%#}で始まる各種制御記法を編集するためには
yuuji@73 503
yuuji@73 504 @table @kbd
yuuji@73 505 @item [prefix] %
yuuji@73 506 @dots{} @code{%#}@var{記法編集メニュー}
yuuji@73 507 @end table
yuuji@73 508
yuuji@73 509 @noindent
yuuji@73 510 を押します。
yuuji@73 511
yuuji@73 512 @example
yuuji@73 513 !)Edit-%#! B)EGIN-END-region L)Edit-%#LPR
yuuji@73 514 @end example
yuuji@73 515
yuuji@73 516 @noindent
yuuji@73 517 というメニューが出て来るので、@code{%#!}に続くコマンドを変更したい時には
yuuji@73 518 @kbd{!}を、@code{%#LPR}で lpr フォーマットを変えたい時は@kbd{l}を、あらか
yuuji@73 519 じめ設定したリジョンを @code{%#BEGIN} 〜 @code{%#END} で括りたい時は、
yuuji@73 520 @kbd{b}を押します。@kbd{b}を選んだ時には、それまでバッファ中に置かれていた
yuuji@73 521 @code{%#BEGIN}, @code{%#END} が自動的に消去されます。
yuuji@73 522 @cindex lprフォーマットの変更[lprふおおまつとのへんこう]
yuuji@73 523
yuuji@73 524 @node Completion, Local dictionary, %#notation , Top
yuuji@73 525 @comment node-name, next, previous, up
yuuji@73 526 @chapter 補完入力
yuuji@73 527
yuuji@73 528 La@TeX{} での環境名などは、野鳥の補完機能を利用して能率的に入力すること
yuuji@73 529 ができます。
yuuji@73 530
yuuji@73 531 @menu
yuuji@73 532 * begin型補完::
yuuji@73 533 * section型補完::
yuuji@73 534 * large型補完::
yuuji@73 535 * maketitle型補完::
yuuji@73 536 * Arbitrary completion:: 随時補完
yuuji@73 537 * end補完::
yuuji@73 538 * Accent mark completion:: アクセント記号補完
yuuji@73 539 * Image completion:: 数式記号イメージ補完
yuuji@73 540 * Greek letter completion:: ギリシャ文字補完
yuuji@73 541 @end menu
yuuji@73 542
yuuji@73 543 @node begin型補完, section型補完, Completion, Completion
yuuji@73 544 @comment node-name, next, previous, up
yuuji@73 545 @section begin型補完
yuuji@73 546 @cindex begin型補完[beginかたほかん]
yuuji@73 547 @cindex 環境名の補完[かんきようめいのほかん]
yuuji@73 548 @cindex prefix b
yuuji@73 549
yuuji@73 550 @code{\begin@{env@}...\end@{env@}}の様な形式の入力の補完をbegin型補完と
yuuji@73 551 呼ぶことにします。begin 型補完は、
yuuji@73 552
yuuji@73 553 @table @kbd
yuuji@73 554 @item [prefix] b
yuuji@73 555 @dots{} begin 型補完開始(標準では @kbd{C-c b})
yuuji@73 556 @end table
yuuji@73 557
yuuji@73 558 @noindent
yuuji@73 559 で始まります。頻繁に用いられる次の La@TeX{} 環境の補完は、[prefix] @kbd{b}
yuuji@73 560 に続く次の1文字を入力するだけで、@code{\begin@{xxx@}...\end@{xxx@}}を完成
yuuji@73 561 させます。
yuuji@73 562
yuuji@73 563 @table @kbd
yuuji@73 564 @item [prefix] b c
yuuji@73 565 @dots{} @code{\begin@{center@}...\end@{center@}}
yuuji@73 566 @item [prefix] b d
yuuji@73 567 @dots{} @code{\begin@{document@}...\end@{document@}}
yuuji@73 568 @item [prefix] b D
yuuji@73 569 @dots{} @code{\begin@{description@}...\end@{description@}}
yuuji@73 570 @item [prefix] b e
yuuji@73 571 @dots{} @code{\begin@{enumerate@}...\end@{enumerate@}}
yuuji@73 572 @item [prefix] b E
yuuji@73 573 @dots{} @code{\begin@{equation@}...\end@{equation@}}
yuuji@73 574 @item [prefix] b i
yuuji@73 575 @dots{} @code{\begin@{itemize@}...\end@{itemize@}}
yuuji@73 576 @item [prefix] b l
yuuji@73 577 @dots{} @code{\begin@{flushleft@}...\end@{flushleft@}}
yuuji@73 578 @item [prefix] b m
yuuji@73 579 @dots{} @code{\begin@{minipage@}...\end@{minipage@}}
yuuji@73 580 @item [prefix] b t
yuuji@73 581 @dots{} @code{\begin@{tabbing@}...\end@{tabbing@}}
yuuji@73 582 @item [prefix] b T
yuuji@73 583 @dots{} @code{\begin@{tabular@}...\end@{tabular@}}
yuuji@73 584 @item [prefix] b ^T
yuuji@73 585 @dots{} @code{\begin@{table@}...\end@{table@}}
yuuji@73 586 @item [prefix] b p
yuuji@73 587 @dots{} @code{\begin@{picture@}...\end@{picture@}}
yuuji@73 588 @item [prefix] b q
yuuji@73 589 @dots{} @code{\begin@{quote@}...\end@{quote@}}
yuuji@73 590 @item [prefix] b Q
yuuji@73 591 @dots{} @code{\begin@{quotation@}...\end@{quotation@}}
yuuji@73 592 @item [prefix] b r
yuuji@73 593 @dots{} @code{\begin@{flushright@}...\end@{flushright@}}
yuuji@73 594 @item [prefix] b v
yuuji@73 595 @dots{} @code{\begin@{verbatim@}...\end@{verbatim@}}
yuuji@73 596 @item [prefix] b V
yuuji@73 597 @dots{} @code{\begin@{verse@}...\end@{verse@}}
yuuji@73 598 @end table
yuuji@73 599
yuuji@73 600 上記のもの以外の環境名は Emacs の持つインクリメンタルな補完機能を用いて
yuuji@73 601 入力します(上記の環境名も以下の補完入力可能)。
yuuji@73 602
yuuji@73 603 @table @kbd
yuuji@73 604 @item [prefix] b @key{SPC}
yuuji@73 605 @dots{} begin 型補完入力
yuuji@73 606 @end table
yuuji@73 607
yuuji@73 608 @kbd{[prefix] b @key{SPC}} と入力すると、最下行のミニバッファに
yuuji@73 609
yuuji@73 610 @example
yuuji@73 611 Begin environment(default document):
yuuji@73 612 @end example
yuuji@73 613
yuuji@73 614 @noindent
yuuji@73 615 と表示されます。ここで、何も入れずにリターンキーのみ押すと、括弧内に出てい
yuuji@73 616 るデフォルトの環境名が入力されますが、適当な環境名を入力すると、
yuuji@73 617 @code{\begin@{環境名@} … \end@{環境名@}}が文書中に挿入されます。ミニバッ
yuuji@73 618 ファで環境名を入力するときに、環境名の頭文字を入力し「スペース」をたたくと、
yuuji@73 619 一致する環境名が内部テーブルに存在した場合、正しい環境名に補完されるので、
yuuji@73 620 入力の手間が省けます。内部テーブルに存在しない環境名を入力した時はユーザ専
yuuji@73 621 用のテーブルに登録され、さらにそのテーブルを自動的に、ユーザ辞書(デフォル
yuuji@73 622 トでは @file{~/.yatexrc})に保存します。
yuuji@73 623
yuuji@73 624 さらに、特定の環境を補完入力した時にはその環境で必ず用いられるエントリを自
yuuji@73 625 動挿入します(例: @code{itemize}環境における@code{\item}など)。挿入されたエ
yuuji@73 626 ントリが不要な場合にはundoによって消去して下さい。
yuuji@73 627 @cindex ユーザ辞書[ゆうさししよ]
yuuji@73 628
yuuji@73 629 @subsection 既に書いたテキストを環境で括る
yuuji@73 630
yuuji@73 631 ところで、最初に書いてしまったブロックを後から、itemize 環境の中
yuuji@73 632 に閉じこめたいと思うことがありますが、そのようなときは、あらかじめ
yuuji@73 633 閉じこめたい段落をマークして、begin 型補完の各コマンドの @kbd{[prefix]}
yuuji@73 634 の次の『小文字の 'b'』 を『大文字』に変えて起動して下さい。(または、
yuuji@73 635 @kbd{C-u} を先に打ち、universal argument をつけても可能です)
yuuji@73 636 @cindex ブロック[ふろつく]
yuuji@73 637 @cindex 閉じ込める[としこめる]
yuuji@73 638
yuuji@73 639 例えばあるパラグラフを description 環境の中に入れたいときは、
yuuji@73 640 そのパラグラフをマークしてから、
yuuji@73 641
yuuji@73 642 @table @kbd
yuuji@73 643 @item [prefix] B D
yuuji@73 644 @itemx (または ESC 1 [prefix] b D)
yuuji@73 645 @itemx (または C-u [prefix] b D など)
yuuji@73 646 @end table
yuuji@73 647
yuuji@73 648 とタイプしてください。これは、@kbd{[prefix] b SPC}の補完入力にもあてはまり、
yuuji@73 649 @kbd{b} を大文字に変えて、@kbd{[prefix] B SPC} とタイプすれば、あらかじめ
yuuji@73 650 マークしておいたリジョンを、begin と end の環境で括ります。
yuuji@73 651
yuuji@73 652 @node section型補完, large型補完, begin型補完, Completion
yuuji@73 653 @comment node-name, next, previous, up
yuuji@73 654 @section section型補完
yuuji@73 655 @cindex section型補完[sectionかたほかん]
yuuji@73 656 @cindex prefix s
yuuji@73 657
yuuji@73 658 @code{\section@{目的@}} のような形式の入力の補完を section 型補完と呼ぶこ
yuuji@73 659 とにします。section 型補完は、
yuuji@73 660
yuuji@73 661 @table @kbd
yuuji@73 662 @item [prefix] s
yuuji@73 663 @dots{} section 型補完
yuuji@73 664 @end table
yuuji@73 665
yuuji@73 666 @noindent
yuuji@73 667 で実行します。@kbd{[prefix] s} を入力するとミニバッファに、
yuuji@73 668
yuuji@73 669 @example
yuuji@73 670 (C-v for view-section) \???@{@} (default documentclass):
yuuji@73 671 @end example
yuuji@73 672
yuuji@73 673 @noindent
yuuji@73 674 というプロンプトが現れるので、そこで @samp{section} のような La@TeX{} コマ
yuuji@73 675 ンド名を入力します。ここでもリターンキーのみで括弧内のデフォルト値が選択さ
yuuji@73 676 れるほか、@samp{chapter}などのような頻度の高い名称入力にはスペースキーによ
yuuji@73 677 る補完機能が有効です。 次に、@{@}の中身の入力を促す、
yuuji@73 678
yuuji@73 679 @example
yuuji@73 680 \section@{???@}:
yuuji@73 681 @end example
yuuji@73 682
yuuji@73 683 @noindent
yuuji@73 684 というプロンプトが現れるので、セクションのタイトルなどを入力します。
yuuji@73 685 たとえば、
yuuji@73 686
yuuji@73 687 @example
yuuji@73 688 (C-v for view-section) \???@{@} (default documentclass): section
yuuji@73 689 \section@{???@}: 目的
yuuji@73 690 @end example
yuuji@73 691
yuuji@73 692 @noindent
yuuji@73 693 のように入力した場合は、文章中に
yuuji@73 694
yuuji@73 695 @example
yuuji@73 696 \section@{目的@}
yuuji@73 697 @end example
yuuji@73 698
yuuji@73 699 @noindent
yuuji@73 700 が挿入され、
yuuji@73 701
yuuji@73 702 @example
yuuji@73 703 (C-v for view-section) \???@{@} (default section): vspace*
yuuji@73 704 \vspace*@{???@}:
yuuji@73 705 @end example
yuuji@73 706
yuuji@73 707 @noindent
yuuji@73 708 のように@{@}の中身を省略したときは、
yuuji@73 709
yuuji@73 710 @example
yuuji@73 711 \vspace*@{@}
yuuji@73 712 @end example
yuuji@73 713
yuuji@73 714 @noindent
yuuji@73 715 だけが挿入され、改行はせずカーソルは自動的に中括弧の内側に移動します。
yuuji@73 716
yuuji@73 717 @menu
yuuji@73 718 * 2個以上の引数をとる section型コマンド::
yuuji@73 719 * Enclose section-type command:: 括り補完
yuuji@73 720 * Recursive completion:: 再帰補完
yuuji@73 721 * view-sectioning:: セクション区切りのアウトライン表示
yuuji@80 722 * label-generation:: ラベル自動生成
yuuji@73 723 @end menu
yuuji@73 724
yuuji@73 725 @node 2個以上の引数をとる section型コマンド, Enclose section-type command, section型補完, section型補完
yuuji@73 726 @comment node-name, next, previous, up
yuuji@73 727 @subsection 2個以上の引数をとる section型コマンド
yuuji@73 728 @cindex 引数[ひきすう]
yuuji@73 729
yuuji@73 730 ところで、@samp{\addtolength@{\topmargin@}@{8mm@}} などのように、引数を二つ
yuuji@73 731 以上取る La@TeX{} コマンドがあります。このようなコマンドの補完入力には、
yuuji@73 732 section 型補完呼び出しに引数を付けてください。例えば上の@samp{addtolength}
yuuji@73 733 の例であれば、引数2を指定します。つまり、
yuuji@73 734
yuuji@73 735 @example
yuuji@73 736 C-u 2 [prefix] s (または、ESC 2 [prefix] s)
yuuji@73 737 @end example
yuuji@73 738
yuuji@73 739 @noindent
yuuji@73 740 と section 型補完を呼び出した後、
yuuji@73 741
yuuji@73 742 @example
yuuji@73 743 (Ctrl-v for view-section) \???@{@} (default vspace*): addtolength
yuuji@73 744 \addtolength@{???@}: \topmargin
yuuji@73 745 Argument 2: 8mm
yuuji@73 746 @end example
yuuji@73 747
yuuji@73 748 @noindent
yuuji@73 749 のように入力してください。最初の addtolength の部分と、第一引数である
yuuji@73 750 \topmargin の入力は当然スペースによる補完入力が可能です。ユーザ辞書に登録
yuuji@73 751 される La@TeX{} コマンドには、この引数の数も学習されるので、最初の補完の時
yuuji@73 752 引数の数を指定して起動しておけば、以後の補完時には、記憶された個数だけ引数
yuuji@73 753 を聞いて来るようになります。あとで引数の個数を変えたい時は、再び @kbd{C-u}
yuuji@73 754 を用いて個数を指定し直すことで、自動的に辞書中の引数の個数の部分を更新しま
yuuji@73 755 す。
yuuji@73 756 @cindex 引数の個数を変える[ひきすうのこすうをかえる]
yuuji@73 757
yuuji@73 758
yuuji@73 759 @node Enclose section-type command, Recursive completion, 2個以上の引数をとる section型コマンド, section型補完
yuuji@73 760 @subsection 既に書いたテキストを括る
yuuji@73 761 @cindex 括る[くくる]
yuuji@73 762
yuuji@73 763 また、起動コマンドの@kbd{s}を大文字に変えて起動すると、あらかじめ書
yuuji@73 764 いた文章を section 型コマンドの第一引数として括ります。
yuuji@73 765
yuuji@73 766 @node Recursive completion, view-sectioning, Enclose section-type command, section型補完
yuuji@73 767 @comment node-name, next, previous, up
yuuji@73 768 @subsection 再帰補完
yuuji@73 769 @cindex 再帰補完[さいきほかん]
yuuji@73 770
yuuji@73 771 高度な使い方になるかもしれませんが、section型補完の引数の入力時にさらに
yuuji@73 772 補完入力を利用することができます(section/large/maketitle型に限る)。section
yuuji@73 773 型コマンドの引数に更に La@TeX{} コマンドが来る場合にはミニバッファで野鳥の
yuuji@73 774 補完キーを再帰的に入力することで引数の入力も効率的に行なえます。
yuuji@73 775
yuuji@80 776 @node view-sectioning, label-generation, Recursive completion, section型補完
yuuji@73 777 @comment node-name, next, previous, up
yuuji@73 778 @subsection セクション区切りのアウトライン表示
yuuji@73 779 @cindex アウトライン[あうとらいん]
yuuji@73 780
yuuji@73 781 通常のsection型補完の時にミニバッファで@kbd{C-v}を押すと現在存在するセク
yuuji@73 782 ション区切りコマンド全てを @code{*Sectioning Lines*}というバッファに一覧表
yuuji@73 783 示します(「<<--」のついている行がもっとも近いセクション区切り)。この時ミニ
yuuji@73 784 バッファで@kbd{C-p}, @kbd{C-n} を押すと@samp{part}, @samp{chapter}, ...,
yuuji@73 785 @samp{subparagraph} のコマンドが論理階層の高さにしたがって上下します。また、
yuuji@73 786 @kbd{C-v}, @kbd{M-v} を押すとセクション区切り一覧バッファがスクロールし、
yuuji@73 787 数字の@kbd{0}〜@kbd{7}を押すとある高さ以上のセクション区切りだけを選んで表
yuuji@73 788 示します(実際にやって見れば分かります)。
yuuji@73 789
yuuji@73 790 @code{*Sectioning Lines*}バッファは、
yuuji@73 791
yuuji@73 792 @table @kbd
yuuji@73 793 @item M-x YaTeX-section-overview
yuuji@73 794 @dots{} セクション区切り一覧バッファを生成
yuuji@73 795 @end table
yuuji@73 796
yuuji@73 797 @cindex セクション区切り一覧バッファ[せくしよんくきりいちらんはつふあ]
yuuji@73 798 で作成することができます。このバッファを選択し任意の行でスペースを押すと、
yuuji@73 799 該当するセクション区切りのある本文中の場所にジャンプします。さらに、同バッ
yuuji@73 800 ファで @kbd{u} を押すと、ソーステキストの対応するセクションコマンドが一階
yuuji@73 801 層上がり(例: subsection が section に変わる)、@kbd{d}を押すと一階層下がり
yuuji@73 802 ます。@code{*Sectioning Lines*}バッファにあるセクション区切りの行をマーク
yuuji@73 803 しておいて@kbd{U}を押すとリジョン内のものに対応するソーステキストのセクショ
yuuji@73 804 ンコマンドすべてが一階層上がり、@kbd{D}を押すと下がります。セクション区切
yuuji@73 805 り一覧バッファで利用できるキーコマンドには以下のものがあります。
yuuji@73 806
yuuji@73 807 @table @kbd
yuuji@73 808 @item SPC
yuuji@73 809 @dots{} 対応するソース行へジャンプ
yuuji@73 810 @item .
yuuji@73 811 @dots{} 対応するソース行を表示
yuuji@73 812 @item u
yuuji@73 813 @dots{} カーソル位置に対応するセクションコマンドを一階層上げる
yuuji@73 814 @item d
yuuji@73 815 @dots{} カーソル位置に対応するセクションコマンドを一階層下げる
yuuji@73 816 @item U
yuuji@73 817 @dots{} マークしたセクションコマンドを一階層上げる
yuuji@73 818 @item D
yuuji@73 819 @dots{} マークしたセクションコマンドを一階層上げる
yuuji@73 820 @item 0〜6
yuuji@73 821 @dots{} レベル n 以下のセクションコマンドを隠して表示
yuuji@73 822 @end table
yuuji@73 823
yuuji@73 824 @cindex 論理階層[ろんりかいそう]
yuuji@73 825 @cindex セクション区切り[せくしよんくきり]
yuuji@73 826 @cindex ジャンプ[しやんふ]
yuuji@73 827
yuuji@80 828 @node label-generation, , view-sectioning, section型補完
yuuji@80 829 @comment node-name, next, previous, up
yuuji@80 830 @subsection ラベル自動生成
yuuji@80 831 @cindex ラベル自動生成[らへるしとうせいせい]
yuuji@80 832
yuuji@80 833 @code{\ref@{@}} や @code{\cite{@@}} マクロをsection型補完で入れた場合
yuuji@80 834 参照先となり得るものを全て探してメニューにして選択できます。参照先には
yuuji@80 835 @code{\label@{@}}をつけておく必要はありません。もしあれば、そのラベルを
yuuji@80 836 使い、なければその場で参照先に@code{\label@{@}}を作らせてくれます。
yuuji@80 837 ラベル名を考えるのは苦痛に感じるものです。全てのカウンタにラベルを
yuuji@80 838 つけるのもたいへんです。もうラベル名に何をつけるか、ラベルをつけるかつけま
yuuji@80 839 いか、などということは忘れましょう!
yuuji@80 840
yuuji@73 841 @node large型補完, maketitle型補完, section型補完, Completion
yuuji@73 842 @comment node-name, next, previous, up
yuuji@73 843 @section large型補完
yuuji@73 844 @cindex large型補完[largeかたほかん]
yuuji@73 845 @cindex prefix l
yuuji@73 846
yuuji@73 847 @code{@{\large @}} のような形式の補完を large 型補完と呼ぶことにします。
yuuji@73 848
yuuji@73 849 @table @kbd
yuuji@73 850 @item [prefix] l
yuuji@73 851 @dots{} large 型補完開始
yuuji@73 852 @end table
yuuji@73 853
yuuji@73 854 @noindent
yuuji@73 855 がlarge型補完の開始です。@kbd{[prefix] l} を押すと、ミニバッファに
yuuji@73 856
yuuji@73 857 @example
yuuji@73 858 @{\??? @} (default large):
yuuji@73 859 @end example
yuuji@73 860
yuuji@73 861 @noindent
yuuji@73 862 と表示されるので、上記のものと同じ要領で補完入力して下さい。補完候補に用意
yuuji@73 863 されているのは、@samp{footnotesize} や @samp{huge} のような文字サイズ指定
yuuji@73 864 子と、@samp{bf}や@samp{dg}のようなフォント指定子です。
yuuji@73 865 @cindex 文字サイズ指定子[もしさいすしていし]
yuuji@73 866 @cindex フォント指定子[ふおんとしていし]
yuuji@73 867
yuuji@73 868 @subsection 既に書いた文字を括る
yuuji@73 869 @cindex 括る[くくる]
yuuji@73 870
yuuji@73 871 また、begin型補完の時と同様、先に書いてしまった一連の文章の文字のサイズ
yuuji@73 872 を変えたいと思う時がありますが、そのような時は、サイズや大きさを変えたい文
yuuji@73 873 字の範囲をマークしてから、呼び出しキーを @kbd{[prefix] L} と、大文字の L
yuuji@73 874 に変えて呼び出せば、そのリジョン全体が、ブレースで囲まれます。
yuuji@73 875
yuuji@73 876 @node maketitle型補完, Arbitrary completion, large型補完, Completion
yuuji@73 877 @comment node-name, next, previous, up
yuuji@73 878 @section maketitle型補完
yuuji@73 879 @cindex maketitle型補完[maketitleかたほかん]
yuuji@73 880 @cindex prefix m
yuuji@73 881
yuuji@73 882 @code{\maketitle} の形式の補完を maketitle 型補完と呼ぶことにします。
yuuji@73 883
yuuji@73 884 @table @kbd
yuuji@73 885 @item [prefix] m
yuuji@73 886 @dots{} maketitle 型補完開始
yuuji@73 887 @end table
yuuji@73 888
yuuji@73 889 @noindent
yuuji@73 890 で、maketitle 型補完を開始します。補完の要領は今までのものとまったく同じで
yuuji@73 891 す。La@TeX{} 用のコマンド名が補完候補として用意されています。
yuuji@73 892
yuuji@73 893 @node Arbitrary completion, end補完, maketitle型補完, Completion
yuuji@73 894 @comment node-name, next, previous, up
yuuji@73 895 @section 随時補完
yuuji@73 896 @cindex 随時補完[すいしほかん]
yuuji@73 897 @cindex prefix SPC
yuuji@73 898
yuuji@73 899 さて、今まで述べた典型的な La@TeX{} コマンド形式の補完入力を用いずに、今
yuuji@73 900 入力しようとしている La@TeX{} コマンドを文書中の任意の位置で随時補完するこ
yuuji@73 901 ともできます。La@TeX{} コマンド(先頭が\で始まる)を入力している途中で、
yuuji@73 902
yuuji@73 903 @table @kbd
yuuji@73 904 @item [prefix] SPC
yuuji@73 905 @dots{} 随時補完
yuuji@73 906 @end table
yuuji@73 907
yuuji@73 908 @noindent
yuuji@73 909 を入力すれば、全ての補完候補の中から一致するものが選ばれカーソル位置に挿入
yuuji@73 910 されます。
yuuji@73 911
yuuji@73 912 @node end補完, Accent mark completion, Arbitrary completion, Completion
yuuji@73 913 @comment node-name, next, previous, up
yuuji@73 914 @section end補完
yuuji@73 915 @cindex end補完[endほかん]
yuuji@73 916 @cindex prefix e
yuuji@73 917
yuuji@73 918 現在開いたままの環境名を自動的に検出し、@code{\end@{環境名@}}を挿入しま
yuuji@73 919 す。begin 型補完を用いれば環境の閉じ忘れはないのですが、時にはついつい手で
yuuji@73 920 @code{\begin@{環境名@}} を入れてしまい、悲しい思いをすることがあります。そ
yuuji@73 921 のような時には気にせず続けて文章を入力し、しかるのちに
yuuji@73 922
yuuji@73 923 @table @kbd
yuuji@73 924 @item [prefix] e
yuuji@73 925 @dots{} end 補完
yuuji@73 926 @end table
yuuji@73 927
yuuji@73 928 @noindent
yuuji@73 929 とすることで、現在開いている環境名で \end@{@} が補われます。
yuuji@73 930
yuuji@73 931 @node Accent mark completion, Image completion, end補完, Completion
yuuji@73 932 @comment node-name, next, previous, up
yuuji@73 933 @section アクセント記号補完
yuuji@73 934 @cindex アクセント記号補完[あくせんときこうほかん]
yuuji@73 935 @cindex prefix a
yuuji@73 936 @cindex 欧文[おうふん]
yuuji@73 937
yuuji@73 938 欧文のアクセント記号(@code{\`@{o@}}など)を入力する時は、
yuuji@73 939
yuuji@73 940 @table @kbd
yuuji@73 941 @item [prefix] a
yuuji@73 942 @dots{} アクセント記号入力
yuuji@73 943 @end table
yuuji@73 944
yuuji@73 945 @noindent
yuuji@73 946 を押すと、ミニバッファに
yuuji@73 947
yuuji@73 948 @example
yuuji@73 949 1:` 2:' 3:^ 4:" 5:~ 6:= 7:. u v H t c d b
yuuji@73 950 @end example
yuuji@73 951
yuuji@73 952 @noindent
yuuji@73 953 というメニューが出て来るので、数字、または対応する記号/英字を入力
yuuji@73 954 して下さい。すると編集バッファに、
yuuji@73 955
yuuji@73 956 @example
yuuji@73 957 \`@{@}
yuuji@73 958 @end example
yuuji@73 959
yuuji@73 960 @noindent
yuuji@73 961 があらわれ、カーソルが@{@}内に位置するので、さらに一文字入力する事で、
yuuji@73 962
yuuji@73 963 @example
yuuji@73 964 \`@{o@}
yuuji@73 965 @end example
yuuji@73 966
yuuji@73 967 @noindent
yuuji@73 968 が完成され、カーソルは@{@}の外に戻ります。
yuuji@73 969
yuuji@73 970 @node Image completion, Greek letter completion, Accent mark completion, Completion
yuuji@73 971 @comment node-name, next, previous, up
yuuji@73 972 @section 数式記号イメージ補完
yuuji@73 973 @cindex 数式記号イメージ補完[すうしききこういめえしほかん]
yuuji@73 974 @cindex イメージ補完[いめえしほかん]
yuuji@73 975 @cindex ;
yuuji@73 976 @cindex 数式モード[すうしきもおと]
yuuji@73 977 @cindex 矢印[やしるし]
yuuji@73 978 @cindex Σ[しくま]
yuuji@73 979 @cindex leftarrow
yuuji@73 980 @cindex ∞[むけんたい]
yuuji@73 981
yuuji@73 982 主に数式モードで使用される、矢印やΣなどの記号を擬似的に表現するキー入力
yuuji@73 983 で、La@TeX{} コマンドを入力できます。これは野鳥自身の「数式モード」でのみ
yuuji@73 984 動作します。野鳥はカーソルが@TeX{}の数式環境の中にある時に@kbd{;}や、
yuuji@73 985 @kbd{:}に特殊な機能を持たせます。
yuuji@73 986
yuuji@73 987 さて、例えば、←(leftarrow)をASCII文字だけで表現する場合、一般的には「<-」
yuuji@73 988 のようにしますが、これを利用して、数式記号イメージ入力モードで
yuuji@73 989 @code{\leftarrow}を入力するには、@kbd{;}(セミコロン)を打ってから@kbd{<-}と
yuuji@73 990 入力します。同様に、長い矢印←-(long-leftarrow) をASCII文字だけで表現する
yuuji@73 991 場合「<--」とするので、@code{\longleftarrow}を入力するためには、@kbd{;<--}
yuuji@73 992 と入力します。あるいは無限大記号をASCII文字だけで表現する時は「oo」のよう
yuuji@73 993 にすることから、@code{\infty} を入力する時は、@kbd{;oo}とキー入力します。
yuuji@73 994
yuuji@73 995 これらの操作をまとめると次のようになります。
yuuji@73 996
yuuji@73 997 @example
yuuji@73 998 INPUT 入力される La@TeX{} コマンド
yuuji@73 999 ; < - @code{\leftarrow}
yuuji@73 1000 ; < - - @code{\longleftarrow}
yuuji@73 1001 ; < - - > @code{\longleftrightarrow}
yuuji@73 1002 ; o @code{\circ}
yuuji@73 1003 ; o o @code{\infty}
yuuji@73 1004 @end example
yuuji@73 1005
yuuji@73 1006
yuuji@73 1007 @noindent
yuuji@73 1008 いずれの場合も、イメージ入力を行っている途中で望みのものがバッファ
yuuji@73 1009 に表示されたなら、そこでイメージ入力を止めて次の編集動作に移っても
yuuji@73 1010 構いません。
yuuji@73 1011
yuuji@73 1012 @cindex ;自身[;ししん]
yuuji@73 1013 数式環境中で@samp{;}自身を入力するには@kbd{;;}のようにします。イメージ
yuuji@73 1014 入力の途中でTABを押すと、それまで入力した文字で始まるもの一覧が表示されま
yuuji@73 1015 す。ここで目的の La@TeX{} コマンドまでカーソルを移動し再度TABを押すことで
yuuji@73 1016 その La@TeX{} コマンドがバッファに挿入されます。
yuuji@73 1017
yuuji@73 1018 どのキー入力にどの記号が対応しているか全て知りたい時は、@kbd{;}を押した
yuuji@73 1019 直後にTABを押してください。以下の例は、@kbd{;<}と押した後にTABを押したもの
yuuji@73 1020 です。
yuuji@73 1021
yuuji@73 1022 @example
yuuji@73 1023 KEY LaTeX sequence sign
yuuji@73 1024 < \leq ≦
yuuji@73 1025 << \ll 《
yuuji@73 1026 <- \leftarrow ←
yuuji@73 1027 <= \Leftarrow <=
yuuji@73 1028 @end example
yuuji@73 1029
yuuji@73 1030 左から[入力キー]、[対応する La@TeX{} コマンド]、[(擬似)記号図示]、と
yuuji@73 1031 いう順でメニューが出て来るので、よく使うものを覚えておくと良いでしょ
yuuji@73 1032 う。ものによってはASCII文字で表現することが困難なので、あまり覚え
yuuji@73 1033 やすいキー並びではないものがあるでしょうから、そのような場合は
yuuji@73 1034 \maketitle 型補完で入力するか、以下に述べる対応表の設定を行って単
yuuji@73 1035 純なキー並びのものを設定すると良いでしょう。
yuuji@73 1036
yuuji@73 1037 入力キーと La@TeX{} コマンド、記号の対応表を個人的に設定したい場合は
yuuji@73 1038 Emacs-Lisp 変数 @code{YaTeX-math-sign-alist-private} に定義してください。
yuuji@73 1039 その内容とデフォルトのものを合わせたものが対応表として使用されます(private
yuuji@73 1040 の方が優先される)。なお、この変数の構造については @file{yatexmth.el} を参
yuuji@73 1041 照してください。
yuuji@73 1042 @cindex YaTeX-math-sign-alist-private
yuuji@73 1043
yuuji@73 1044 @node Greek letter completion, , Image completion, Completion
yuuji@73 1045 @comment node-name, next, previous, up
yuuji@73 1046 @section ギリシャ文字補完
yuuji@73 1047 @cindex ギリシャ文字補完[きりしやもしほかん]
yuuji@73 1048 @cindex :
yuuji@73 1049
yuuji@73 1050 もう一つ、数式環境中で@kbd{:}を押すとギリシャ文字入力モードに入ります。
yuuji@73 1051 @kbd{:}を押した直後に@kbd{a}を押すと@code{\alpha}が、@kbd{g} を押すと
yuuji@73 1052 @code{\gamma}が、などアルファベットに対応したギリシャ文字が挿入されます。
yuuji@73 1053 操作方法は;の数式記号補完とまったく同じです。まずは@kbd{:}の直後に
yuuji@73 1054 TABを押してどのアルファベットにどのギリシャ文字が対応しているか調べてみて
yuuji@73 1055 ください。
yuuji@73 1056
yuuji@73 1057 @kbd{;}と@kbd{:}を数式環境中で押しているにもかかわらず、イメージ補完が働
yuuji@73 1058 かない場合は、@kbd{C-u ;}のように universal-argument をつけてキーを押すこ
yuuji@73 1059 とにより、強制的にイメージ補完に入ることができます。また、この時にどのよう
yuuji@73 1060 な状態で数式環境内判定に失敗したかをご連絡下さい。
yuuji@73 1061
yuuji@73 1062 @node Local dictionary, Commenting out, Completion, Top
yuuji@73 1063 @comment node-name, next, previous, up
yuuji@73 1064 @chapter ローカル辞書
yuuji@73 1065 @cindex ローカル辞書[ろおかるししよ]
yuuji@73 1066 @cindex .yatexrc
yuuji@73 1067
yuuji@73 1068 補完入力用の候補は三種類の辞書から構成されています。一つは
yuuji@73 1069 @file{yatex.el}に組み込まれた「標準辞書」、もう一つはユーザが個人的に常用
yuuji@73 1070 するコマンドを保存する「ユーザ辞書」、そしてもうひとつはあるディレクトリで
yuuji@73 1071 のみ有効なコマンドを保存する「ローカル辞書」です。
yuuji@73 1072
yuuji@73 1073 補完入力時に新しい単語を入れた場合に、その単語をどの辞書に入れるか聞いて
yuuji@73 1074 来ます。
yuuji@73 1075
yuuji@73 1076 @example
yuuji@73 1077 `foo' is not in table. Register into: U)serDic L)ocalDic N)one D)iscard
yuuji@73 1078 @end example
yuuji@73 1079
yuuji@73 1080 @noindent
yuuji@73 1081 というプロンプトに対し、@kbd{u}と答えると「ユーザ辞書」を、@kbd{l}と答える
yuuji@73 1082 とローカル辞書を更新し、@kbd{n}と答えると辞書ファイルは更新せず現在のEmacs
yuuji@73 1083 セッションのみ有効な単語とし、@kbd{d}と答えると新たな単語を学習せずに捨て
yuuji@73 1084 ることになります。
yuuji@73 1085
yuuji@73 1086 もし、ローカル辞書の機能はいらず、全てユーザ辞書の更新のみでよいと言う場
yuuji@73 1087 合には@file{~/.emacs}などで、
yuuji@73 1088 @cindex YaTeX-nervous
yuuji@73 1089
yuuji@73 1090 @lisp
yuuji@73 1091 (setq YaTeX-nervous nil)
yuuji@73 1092 @end lisp
yuuji@73 1093
yuuji@73 1094 @noindent
yuuji@73 1095 として下さい。
yuuji@73 1096
yuuji@73 1097 @node Commenting out, Cursor jump, Local dictionary, Top
yuuji@73 1098 @comment node-name, next, previous, up
yuuji@73 1099 @chapter コメントアウト
yuuji@73 1100 @cindex コメントアウト[こめんとあうと]
yuuji@73 1101 @cindex prefix <
yuuji@73 1102 @cindex prefix >
yuuji@73 1103 @cindex prefix .
yuuji@73 1104 @cindex prefix ,
yuuji@73 1105
yuuji@73 1106
yuuji@73 1107 La@TeX{}の編集には試行錯誤がつきものです。ある部分を一括でコメントアウト
yuuji@73 1108 したり、コメントを外したりしたいことがあります。
yuuji@73 1109
yuuji@73 1110 @table @kbd
yuuji@73 1111 @item [prefix] >
yuuji@73 1112 @dots{} リジョンを % でコメントアウト
yuuji@73 1113 @item [prefix] <
yuuji@73 1114 @dots{} リジョンの % のコメントを外す
yuuji@73 1115 @end table
yuuji@73 1116
yuuji@73 1117 @noindent
yuuji@73 1118 は、あらかじめ設定したリジョンに対しての操作、
yuuji@73 1119
yuuji@73 1120 @table @kbd
yuuji@73 1121 @item [prefix] .
yuuji@73 1122 @dots{} 現在のパラグラフをコメントアウト
yuuji@73 1123 @item [prefix] ,
yuuji@73 1124 @dots{} 現在のパラグラフのコメントを外す
yuuji@73 1125 @end table
yuuji@73 1126
yuuji@73 1127 @noindent
yuuji@73 1128 は、カーソルの位置するパラグラフ全体に対しての操作です。なお、ここでいう
yuuji@73 1129 「パラグラフ」は (@code{mark-paragraph}) 関数によりマークされる範囲を指し
yuuji@73 1130 ます(標準設定で@kbd{ESC h}にバインドされている)。なお、既に@code{%}でコメ
yuuji@73 1131 ントアウトされているパラグラフに対して繰り返しパラグラフのコメントを使用し
yuuji@73 1132 た場合の動作は保証しませんので御注意ください。
yuuji@73 1133
yuuji@73 1134 さて、文章に対してだけでなく、時には@code{\begin}, @code{\end} 自体に対
yuuji@73 1135 してもコメントアウトの操作をしたいときがあります。このようなときは、
yuuji@73 1136 @code{\begin@{@}} あるいは @code{\end@{@}} の行にカーソルを合わせ、
yuuji@73 1137
yuuji@73 1138 @table @kbd
yuuji@73 1139 @item [prefix] >
yuuji@73 1140 @dots{} @code{\begin@{@}}〜@code{\end@{@}} 全てコメントアウト
yuuji@73 1141 @item [prefix] <
yuuji@73 1142 @dots{} @code{\begin@{@}}〜@code{\end@{@}} 全てコメントを外す
yuuji@73 1143 @end table
yuuji@73 1144
yuuji@73 1145 @noindent
yuuji@73 1146 とすることで、@code{\begin〜\end}で囲まれる環境全てに対してコメント操作し、
yuuji@73 1147
yuuji@73 1148 @table @kbd
yuuji@73 1149 @item [prefix] .
yuuji@73 1150 @dots{} @code{\begin@{@}} と @code{\end@{@}} をコメントアウト
yuuji@73 1151 @item [prefix] ,
yuuji@73 1152 @dots{} @code{\begin@{@}} と @code{\end@{@}} のコメントを外す
yuuji@73 1153 @end table
yuuji@73 1154
yuuji@73 1155 は、対応する @code{\begin} と @code{\end} 2行だけを、コメント操作の対象と
yuuji@73 1156 します。リジョンをコメントアウトしようとして、マークを設定したのちにカーソ
yuuji@73 1157 ルを移動し@kbd{[preifx] >} を押してもカーソルが @code{\begin@{@}} の上にあ
yuuji@73 1158 ると@code{\begin@{@}}〜@code{\end@{@}}モードでコメント機能が働いてしまうの
yuuji@73 1159 で注意して下さい。
yuuji@73 1160
yuuji@73 1161 @node Cursor jump, Modifying/Deleting, Commenting out, Top
yuuji@73 1162 @comment node-name, next, previous, up
yuuji@73 1163 @chapter カーソルジャンプ
yuuji@73 1164 @cindex カーソルジャンプ[かあそるしやんふ]
yuuji@73 1165 @cindex prefix g
yuuji@73 1166
yuuji@73 1167
yuuji@73 1168 @menu
yuuji@73 1169 * 対応オブジェクトへのジャンプ::
yuuji@73 1170 * お絵描きツール起動::
yuuji@73 1171 * メインファイルへのジャンプ::
yuuji@73 1172 * 環境を単位としたジャンプ::
yuuji@73 1173 * 最後の補完位置へのジャンプ::
yuuji@73 1174 @end menu
yuuji@73 1175
yuuji@73 1176 @node 対応オブジェクトへのジャンプ, お絵描きツール起動, Cursor jump, Cursor jump
yuuji@73 1177 @comment node-name, next, previous, up
yuuji@73 1178 @section 対応オブジェクトへのジャンプ
yuuji@73 1179
yuuji@73 1180 文書中のいろいろな場所で
yuuji@73 1181
yuuji@73 1182 @table @kbd
yuuji@73 1183 @item [prefix] g
yuuji@73 1184 @dots{} 対応するオブジェクトにジャンプ
yuuji@73 1185 @end table
yuuji@73 1186
yuuji@73 1187 @noindent
yuuji@73 1188 を押すことにより、カーソル位置のLa@TeX{}コマンドに対応する場所にジャンプ
yuuji@73 1189 します。対応関係が存在すると解釈されるコマンドには以下のものがあります。
yuuji@73 1190
yuuji@73 1191 @itemize @bullet
yuuji@73 1192 @item @code{\begin@{@}} ←→ @code{\end@{@}}
yuuji@73 1193 @item @code{%#BEGIN} ←→ @code{%#END}
yuuji@73 1194 @item 画像ファイルの取り込みマクロ → 対応するviewer/お絵かきツール起動
yuuji@73 1195 @item @code{\label@{@}} ←→ @code{\ref@{@}}
yuuji@73 1196 @item @code{\include(\input)} → 対応するファイル
yuuji@73 1197 @item @code{\bibitem@{@}} ←→ @code{\cite@{@}}
yuuji@73 1198 @end itemize
yuuji@73 1199
yuuji@73 1200 @code{\begin@{@}} か @code{\end@{@}} の行で@kbd{[prefix] g}を押すことに
yuuji@73 1201 より、対応する@code{end/begin}の行にジャンプします。もちろん対応するものが
yuuji@73 1202 ない場合はエラーになります。またこれは、領域固定のための @code{%#BEGIN} と
yuuji@73 1203 @code{%#END} のペアに対しても同様に動作します。なお、@code{label/ref}や
yuuji@73 1204 @code{cite/bibitem}対応するものが別ファイルにある時は、ジャンプ先となるファ
yuuji@73 1205 イルがオープンされていなければなりません。@xref{%#notation}.
yuuji@73 1206 メインの .tex ファイルの @code{\include@{chap1@}} などにカーソルを合わせ、
yuuji@73 1207 @kbd{[prefix] g} を押すと、@file{chap1.tex} にジャンプします。
yuuji@73 1208
yuuji@73 1209 また、
yuuji@73 1210
yuuji@73 1211 @table @kbd
yuuji@73 1212 @item [prefix] 4 g
yuuji@73 1213 @dots{} 別ウィンドウで対応オブジェクトにジャンプ
yuuji@73 1214 @end table
yuuji@73 1215
yuuji@73 1216 @noindent
yuuji@73 1217 を押すと、対応するオブジェクトへのジャンプを別ウィンドウで行います。ただし、
yuuji@73 1218 この機能は @code{begin/end}, @code{%#BEGIN/%#END} 間のジャンプに対しては
yuuji@73 1219 (意味がないと思われるので)機能しないので注意してください。
yuuji@73 1220
yuuji@73 1221 @node お絵描きツール起動, メインファイルへのジャンプ, 対応オブジェクトへのジャンプ, Cursor jump
yuuji@73 1222 @comment node-name, next, previous, up
yuuji@73 1223 @section お絵描きツール起動
yuuji@73 1224 @cindex お絵描きツール起動[おえかきつうるきとう]
yuuji@73 1225
yuuji@73 1226 上記の「画像ファイルの取り込みマクロ」とは、例えば
yuuji@73 1227 @code{\epsfile@{file=foo@}} のような挿絵取り込みコマンドのことで、この行に
yuuji@73 1228 カーソルを合わせて@kbd{[prefix] g}を押すとその画像ファイルの元となったファ
yuuji@73 1229 イルを対応するお絵描きツールを起動してオープンします。起動するツールの判定
yuuji@73 1230 は以下のようになされます。
yuuji@73 1231
yuuji@73 1232 @enumerate
yuuji@73 1233 @item
yuuji@73 1234 カレント行が変数 @code{YaTeX-processed-file-regexp-alist} に定義さ
yuuji@73 1235 れている正規表現のいずれかとマッチしたら、ファイル名に相当する部分を
yuuji@73 1236 \\(\\)から抜き出して覚えておく(何番目の\\(\\)かは変数の各リストの cdr 部に
yuuji@73 1237 入れておく)。マッチしなければ何もしない。
yuuji@73 1238 @item
yuuji@73 1239 行末に、変数 @code{YaTeX-file-processor-alist} に登録されているコマンドが
yuuji@73 1240 「%コマンド」 のように書いてあれば強制的に「コマンド ファイル名.拡張子」を
yuuji@73 1241 起動。
yuuji@73 1242 @item
yuuji@73 1243 なければ、変数 @code{YaTeX-file-processor-alist} の各リストのcdr部に入って
yuuji@73 1244 いる拡張子を「ファイル名」の後ろに足したファイルが存在するか順次調べて、存
yuuji@73 1245 在した場合car部に入っているコマンドを起動する。
yuuji@73 1246 @item
yuuji@73 1247 以上どれかにマッチしなければあきらめる。
yuuji@73 1248 @end enumerate
yuuji@73 1249
yuuji@73 1250
yuuji@73 1251 変数 @code{YaTeX-file-processor-alist} と変数
yuuji@73 1252 @code{YaTeX-file-processor-alist} の設定方法についてはそれぞれの変数につい
yuuji@73 1253 て describe-variable して説明を読んで下さい。うまく設定すると、画像ファイ
yuuji@73 1254 ルにかぎらず、任意の形式のファイルを任意のプロセッサで処理するコマンドを簡
yuuji@73 1255 単に呼び出すことができます。
yuuji@73 1256
yuuji@73 1257 @node メインファイルへのジャンプ, 環境を単位としたジャンプ, お絵描きツール起動, Cursor jump
yuuji@73 1258 @comment node-name, next, previous, up
yuuji@73 1259 @section メインファイルへのジャンプ
yuuji@73 1260
yuuji@73 1261 @file{chap1.tex}のようなサブファイルで、
yuuji@73 1262
yuuji@73 1263 @table @kbd
yuuji@73 1264 @item [prefix] ^
yuuji@73 1265 @dots{} メインファイルにジャンプ
yuuji@73 1266 @item [prefix] 4 ^
yuuji@73 1267 @dots{} 別ウィンドウでメインファイルにジャンプ
yuuji@73 1268 @end table
yuuji@73 1269
yuuji@73 1270 @noindent
yuuji@73 1271 を押すと、メインファイルの編集バッファに切替えます。もし、メインファイルを
yuuji@73 1272 オープンしていない場合は、カレントディレクトリから探して自動的にオープンし
yuuji@73 1273 ます。
yuuji@73 1274
yuuji@73 1275 @node 環境を単位としたジャンプ, 最後の補完位置へのジャンプ, メインファイルへのジャンプ, Cursor jump
yuuji@73 1276 @comment node-name, next, previous, up
yuuji@73 1277 @section 環境を単位としたジャンプ
yuuji@73 1278
yuuji@73 1279 さらに現在の環境を単位として機能するコマンドに以下のものがあります。
yuuji@73 1280
yuuji@73 1281 @cindex 環境の先頭へ[かんきようのせんとうへ]
yuuji@73 1282 @cindex 環境の末尾へ[かんきようのまつひへ]
yuuji@73 1283 @cindex 環境をマーク[かんきようをまあく]
yuuji@73 1284 @cindex M-C-a
yuuji@73 1285 @cindex M-C-e
yuuji@73 1286 @cindex M-C-@@
yuuji@73 1287 @table @kbd
yuuji@73 1288 @item M-C-a
yuuji@73 1289 @dots{} 環境の先頭(@code{\begin})へジャンプ
yuuji@73 1290 @item M-C-e
yuuji@73 1291 @dots{} 環境の末尾(@code{\end})へジャンプ
yuuji@73 1292 @item M-C-@@
yuuji@73 1293 @dots{} 環境全体をマーク
yuuji@73 1294 @end table
yuuji@73 1295
yuuji@73 1296 上記のコマンドは通常の@kbd{[prefix]}キーではなく@kbd{META}キーをプリフィク
yuuji@73 1297 スとして機能するのでご注意下さい。
yuuji@73 1298
yuuji@73 1299 @node 最後の補完位置へのジャンプ, , 環境を単位としたジャンプ, Cursor jump
yuuji@73 1300 @comment node-name, next, previous, up
yuuji@73 1301 @section 最後の補完位置へのジャンプ
yuuji@73 1302
yuuji@73 1303 野鳥は補完入力した位置を常にレジスタ @code{3}に保存しています。
yuuji@73 1304 入力途中で如何なるファイルの如何なる位置に行ったとしても、
yuuji@73 1305 @kbd{C-x j 3}(@code{jump-to-register})を使って直ちに最後の補完入力位置に戻
yuuji@73 1306 ることができます。
yuuji@73 1307
yuuji@73 1308 @node Modifying/Deleting, Filling, Cursor jump, Top
yuuji@73 1309 @comment node-name, next, previous, up
yuuji@73 1310 @chapter 変更/削除
yuuji@73 1311 @cindex 変更/削除[へんこう/さくしよ]
yuuji@73 1312 @cindex prefix c
yuuji@73 1313 @cindex prefix k
yuuji@73 1314
yuuji@73 1315 既に入力されている La@TeX{} コマンドの変更/削除のために以下の機能が用意
yuuji@73 1316 されています。
yuuji@73 1317
yuuji@73 1318 @table @kbd
yuuji@73 1319 @item [prefix] c
yuuji@73 1320 @dots{} カーソル位置の La@TeX{} コマンドの変更
yuuji@73 1321 @item [prefix] k
yuuji@73 1322 @dots{} カーソル位置の La@TeX{} コマンドの削除
yuuji@73 1323 @end table
yuuji@73 1324
yuuji@73 1325 @noindent
yuuji@73 1326 これらのコマンドは、コマンドを起動する場所によって動作を決定するので注意し
yuuji@73 1327 て下さい。
yuuji@73 1328
yuuji@73 1329 @menu
yuuji@73 1330 * Changing LaTeX command:: La@TeX{} コマンドの変更
yuuji@73 1331 * Killing LaTeX command:: La@TeX{} コマンドの削除
yuuji@73 1332 @end menu
yuuji@73 1333
yuuji@73 1334 @node Changing LaTeX command, Killing LaTeX command, Modifying/Deleting, Modifying/Deleting
yuuji@73 1335 @comment node-name, next, previous, up
yuuji@73 1336 @section La@TeX{} コマンドの変更
yuuji@73 1337
yuuji@73 1338 変更したい La@TeX{} コマンドにカーソルを合わせて @kbd{[prefix] c}
yuuji@73 1339 を押すとそのコマンドを補完入力などを用いて手軽に変えることができます。
yuuji@73 1340 @kbd{[prefix] c} で変更できるコマンドには以下のものがあります。
yuuji@73 1341
yuuji@73 1342 @itemize
yuuji@73 1343 @item @code{begin/end} の環境名
yuuji@73 1344 @item section型コマンドのコマンド名
yuuji@73 1345 @item section型コマンドの引数
yuuji@73 1346 @item section型コマンドのオプションパラメータ([]で囲まれたもの)
yuuji@73 1347 @item large型コマンド
yuuji@73 1348 @item (イメージ補完で入力可能な)数式モード専用のmaketitle型コマンド
yuuji@73 1349 @end itemize
yuuji@73 1350
yuuji@73 1351 変えたいsection型コマンドの引数がさらに La@TeX{} コマンドを含む場合は、
yuuji@73 1352 その引数を囲む中括弧の上で @kbd{[prefix] c} を押すことで中のコマンドを変更
yuuji@73 1353 対象判定から除外することができます。
yuuji@73 1354
yuuji@73 1355 @cindex 環境名の変更[かんきようめいのへんこう]
yuuji@73 1356
yuuji@73 1357 @node Killing LaTeX command, , Changing LaTeX command, Modifying/Deleting
yuuji@73 1358 @comment node-name, next, previous, up
yuuji@73 1359 @section La@TeX{} コマンドの削除
yuuji@73 1360
yuuji@73 1361 @kbd{[prefix] k} は起動する位置により
yuuji@73 1362 次のような動作を行います。
yuuji@73 1363 @cindex 環境の削除[かんきようのさくしよ]
yuuji@73 1364
yuuji@73 1365
yuuji@73 1366 @example
yuuji@73 1367 起動位置 動作
yuuji@73 1368 \begin, \endの行 @code{\begin\end}ペアの削除
yuuji@73 1369 %#BEGIN, %#END の行 %#BEGIN,%#ENDペアの削除
yuuji@73 1370 section型コマンドの上(中) section型コマンドの削除
yuuji@73 1371 フォント指定括弧の上 フォント指定の削除
yuuji@73 1372 括弧の上 対をなす括弧の削除
yuuji@73 1373 @end example
yuuji@73 1374
yuuji@73 1375 @noindent
yuuji@73 1376 @code{\begin, \end} および @code{%#BEGIN, %#END} を削除する場合、
yuuji@73 1377 @code{\begin, \end} や @code{%#BEGIN, %#END} の存在する行は
yuuji@73 1378 まるごと削除されるので、それらの一行に @code{\begin} などを二つ以上連ねて
yuuji@73 1379 書かないように注意してください。
yuuji@73 1380 上記のものはすべて本文を囲う「容器」を削除するように働きますが、
yuuji@73 1381 universal-argument (@kbd{C-u}) を打った後で@kbd{[prefix] k}をタイプすると、
yuuji@73 1382 それぞれの「容器」に含まれる「中身」も一気に削除します。以下の例を参考にし
yuuji@73 1383 て下さい。
yuuji@73 1384
yuuji@73 1385 @example
yuuji@73 1386 元のテキスト: [prefix] k C-u [prefix] k
yuuji@73 1387 本文\footnote@{脚注@}です。 本文脚注です。 本文です。
yuuji@73 1388 ↑(カーソル位置)
yuuji@73 1389 @end example
yuuji@73 1390
yuuji@73 1391 @node Filling, Includeonly, Modifying/Deleting, Top
yuuji@73 1392 @comment node-name, next, previous, up
yuuji@73 1393 @chapter 桁揃え
yuuji@73 1394 @cindex 桁揃え[けたそろえ]
yuuji@73 1395
yuuji@73 1396 @section itemの桁揃え
yuuji@73 1397 @cindex itemなどの桁揃え[itemなとのけたそろえ]
yuuji@73 1398 @cindex prefix i
yuuji@73 1399
yuuji@73 1400 itemize 環境中にある@code{\item}の項目(文章)が複数行に渡る場合に、項
yuuji@73 1401 目の先頭を桁揃えしたい場合には、
yuuji@73 1402
yuuji@73 1403 @c @table @kbd
yuuji@73 1404 @c @item [prefix] i
yuuji@73 1405 @c @dots{} itemの桁揃え
yuuji@73 1406 @c @end table
yuuji@73 1407
yuuji@73 1408 @table @kbd
yuuji@73 1409 @item M-q
yuuji@73 1410 @dots{} 桁揃え
yuuji@73 1411 @end table
yuuji@73 1412
yuuji@73 1413 @cindex NTT-jTeX[えぬていいていいしえいてつく]
yuuji@73 1414 @noindent
yuuji@73 1415 によって、その item のインデントの深さに応じて fill されます。なお、古い
yuuji@73 1416 NTT jTeX を使用している場合には、Lisp 変数@code{NTT-jTeX}を@code{t}にセッ
yuuji@73 1417 トして下さい。
yuuji@73 1418
yuuji@73 1419 @cindex YaTeX-item-regexp
yuuji@73 1420 このとき、変数@code{YaTeX-item-regexp}の値(標準では @code{"\\\\item"})を
yuuji@73 1421 項目指定コマンドの正規表現として検索に使用します。itemize 環境で、独自のコ
yuuji@73 1422 マンドを定義して項目を列挙している場合(例えば@code{\underlineitem})は、
yuuji@73 1423 @file{~/.emacs} で次のように指定して下さい。
yuuji@73 1424
yuuji@73 1425 @lisp
yuuji@73 1426 (setq YaTeX-item-regexp
yuuji@73 1427 "\\(\\\\\\(sub\\)*item\\)\\|\\(\\\\underlineitem\\)")
yuuji@73 1428 @end lisp
yuuji@73 1429
yuuji@73 1430 @noindent
yuuji@73 1431 この変数の指定の仕方がよく分からない場合は、独自の項目列挙コマンドの名前を
yuuji@73 1432 @code{@code{"\item"}で始まるものにして下さい(例えば"\itembf"})。
yuuji@73 1433
yuuji@73 1434 野鳥の @kbd{M-q} では @code{\item} を環境に応じて以下のように「ハングイン
yuuji@73 1435 デント」します。
yuuji@73 1436
yuuji@73 1437 @example
yuuji@73 1438 itemize, enumerate環境:
yuuji@73 1439 >\item[ほげほげ] 英語では、特に意味のない単語を `foo' であらわしま
yuuji@73 1440 > すが、これの日本語版ともいえる単語が「ほげほげ」
yuuji@73 1441 > です。
yuuji@73 1442 description環境:
yuuji@73 1443 > \item[へろへろ] 「ほげほげ」をでたらめが単語として使った時に、第
yuuji@73 1444 > 2のでたらめな単語として「へろへろ」が使われることが多
yuuji@73 1445 > いようです。
yuuji@73 1446 @end example
yuuji@73 1447
yuuji@73 1448 @section パラグラフの桁揃え
yuuji@73 1449 @cindex パラグラフの桁揃え[はらくらふのけたそろえ]
yuuji@73 1450 @cindex M-q
yuuji@73 1451
yuuji@73 1452 itemize環境以外でのパラグラフの桁揃え(fill)は、基本的に他のモードと同じ
yuuji@73 1453 ように機能しますが、verbatim環境や、tabular環境など桁揃えをすると悲惨な状
yuuji@73 1454 況になるような環境中では機能しません。また、\verb で括ってあるものは決して
yuuji@73 1455 行分割されません(変数 @code{YaTeX-verb-regexp} で制御) )。さらに、一時的に
yuuji@73 1456 インデントの深さを変えてある箇所では、そのインデントの先頭で@kbd{M-q}を押
yuuji@73 1457 すことにより fill-prefix をいちいち変更しなくて桁揃えができます。
yuuji@73 1458
yuuji@73 1459
yuuji@73 1460 @node Includeonly, What column, Filling, Top
yuuji@73 1461 @comment node-name, next, previous, up
yuuji@73 1462 @chapter 勝手にincludeonly
yuuji@73 1463 @cindex 勝手にincludeonly[かつてにincludeonly]
yuuji@73 1464 @cindex includeonly
yuuji@73 1465
yuuji@73 1466 ファイルを分割して文章を入力している時には、メインファイル中に
yuuji@73 1467
yuuji@73 1468 @example
yuuji@73 1469 \includeonly@{現在編集中のファイル名@}
yuuji@73 1470 @end example
yuuji@73 1471
yuuji@73 1472 @noindent
yuuji@73 1473 のように書いておくことで、タイプセットの時間を節約できますが、ちょっと他の
yuuji@73 1474 ファイルを手直ししたい時には
yuuji@73 1475 @cindex 他のファイルの手直し[ほかのふあいるのてなおし]
yuuji@73 1476
yuuji@73 1477 @example
yuuji@73 1478 \includeonly@{ちょっと手直ししたいファイル名@}
yuuji@73 1479 @end example
yuuji@73 1480
yuuji@73 1481 @noindent
yuuji@73 1482 と書き直さなければならず手間がかかります。野鳥では現在編集しているファイル
yuuji@73 1483 名がメインファイルの@code{\includeonly}にない場合には自動的にこれを検出し、
yuuji@73 1484 次の指示を仰ぎます。
yuuji@73 1485
yuuji@73 1486 @example
yuuji@73 1487 A)dd R)eplace %)comment?
yuuji@73 1488 @end example
yuuji@73 1489
yuuji@73 1490 @noindent
yuuji@73 1491 現在編集中のファイルを @code{\includeonly} のリストに加えたい時には@kbd{a}
yuuji@73 1492 を、現在編集中のファイルだけを @code{\includeonly} にしたい時は@kbd{r}を、
yuuji@73 1493 @code{\includeonly} の行をコメントアウトして無効化したい時には、@kbd{%}を
yuuji@73 1494 それぞれ押して下さい。
yuuji@73 1495
yuuji@73 1496 @node What column, Intelligent newline, Includeonly, Top
yuuji@73 1497 @comment node-name, next, previous, up
yuuji@73 1498 @chapter ここはどこ?
yuuji@73 1499 @cindex ここはどこ?[ここはとこ?]
yuuji@73 1500 @cindex prefix &
yuuji@73 1501 @cindex 複雑なtabular[ふくさつなtabular]
yuuji@73 1502
yuuji@73 1503 項目数の多い tabular などをたくさん書いていると下の方の行で、いま書いて
yuuji@73 1504 いる桁がどこに対応するのかわからなくなってしまうことがあります。例えば、以
yuuji@73 1505 下のような tabular において、
yuuji@73 1506
yuuji@73 1507 @example
yuuji@73 1508 \begin@{tabular@}@{|c|c|c|c|c|c|c|c|@}\hline
yuuji@73 1509 氏名&所属&〒&住所&電話&FAX&帰省先&帰省先電話\\ \hline
yuuji@73 1510 矢上二郎 & 6 & 223 & 横浜市港北区日吉 & xxx-yyy &
yuuji@73 1511 zzz-www & トンガ & 9876-54321 \\
yuuji@73 1512 日吉小僧 & 2 & \multicolumn@{2@}@{c|@}@{教えない@}
yuuji@73 1513 &&&(???)
yuuji@73 1514 \\ \hline
yuuji@73 1515 \end@{tabular@}
yuuji@73 1516 @end example
yuuji@73 1517
yuuji@73 1518 @noindent
yuuji@73 1519 (???)の部分がどの項目なのかすぐに判断するのは難しいでしょう。こんな時は、
yuuji@73 1520
yuuji@73 1521 @table @kbd
yuuji@73 1522 @item [prefix] &
yuuji@73 1523 @dots{} 現在のカラム表示
yuuji@73 1524 @end table
yuuji@73 1525 @cindex 現在のカラム表示[けんさいのからむひようし]
yuuji@73 1526
yuuji@73 1527 を押すとカーソル位置のカラムがどの項目に該当するかをミニバッファに表示しま
yuuji@73 1528 す。tabular/array環境の第1行目を項目名の並びとみなして対応するものを探しま
yuuji@73 1529 す。もし項目名として別のものを表示して欲しい場合は、行頭を@code{%}にしてダ
yuuji@73 1530 ミーの項目並びを作っておくと良いでしょう。
yuuji@73 1531
yuuji@79 1532 @node Intelligent newline, Usepackage cheker, What column, Top
yuuji@73 1533 @comment node-name, next, previous, up
yuuji@73 1534 @chapter おまかせ改行
yuuji@73 1535 @cindex おまかせ改行[おまかせかいきよう]
yuuji@73 1536 @cindex &入力[&にゆうりよく]
yuuji@73 1537
yuuji@73 1538 tabular[*], array, itemize, enumerate, tabbing 環境をbegin型補完で入力し
yuuji@73 1539 た時、または各環境内で
yuuji@73 1540
yuuji@73 1541 @table @kbd
yuuji@73 1542 @item ESC RET
yuuji@73 1543 @dots{} おまかせ改行
yuuji@73 1544 @end table
yuuji@73 1545
yuuji@73 1546 @noindent
yuuji@73 1547 を押すと、その環境に応じた行エントリを次の行に挿入します(begin型補完時に自
yuuji@73 1548 動挿入されたエントリが不要な場合は undo によって消去できます)。例えば、
yuuji@73 1549 tabular環境では、その環境のカラム数に対応した個数の @code{&} に加え、行末
yuuji@73 1550 の @code{\\} を入れます。この時それ以前に @code{\hline} があればそれも付け
yuuji@73 1551 加えます。環境とそれに応じて自動入力するものの対応は以下のようになります。
yuuji@73 1552
yuuji@73 1553 @itemize
yuuji@73 1554 @item @code{tabular}, @code{tabular*}, @code{array}
yuuji@73 1555
yuuji@73 1556 カラム数-1 だけの @code{&} と @code{\\}。必要に応じて @code{\hline}
yuuji@73 1557
yuuji@73 1558 @item @code{tabbing}
yuuji@73 1559
yuuji@73 1560 一行目で定義している @code{\=} と同じ個数の @code{\>}。
yuuji@73 1561
yuuji@73 1562 @item @code{itemize}, @code{enumerate}, @code{description}, @code{list}
yuuji@73 1563
yuuji@73 1564 @code{\item} または @code{item[]}
yuuji@73 1565 @end itemize
yuuji@73 1566
yuuji@73 1567 tabular 環境の例のように、本機能は各環境の一行目の内容を参考にして動作す
yuuji@73 1568 るので、なるべく二行目以降で呼び出すようにしてください。
yuuji@73 1569
yuuji@73 1570 もし、その他の環境、例えば @code{foo}、に対して@code{おまかせ改行}を動作
yuuji@73 1571 させたい時は、@code{YaTeX-intelligent-newline-foo} という名前の関数を定義
yuuji@73 1572 します。定義した関数は、現在の行に改行を挿入した直後の行頭の位置で呼ばれま
yuuji@73 1573 す。関数 @code{YaTeX-indent-line} を呼ぶと現在の環境のネストに応じた深さに
yuuji@73 1574 インデントされるので、これを呼んでから何かを挿入するようなコードを書くとよ
yuuji@73 1575 いでしょう。@file{yatexenv.el}内の関数
yuuji@73 1576 @code{YaTeX-intelligent-newline-itemize} の定義などを参考にしてください。
yuuji@73 1577
yuuji@80 1578
yuuji@79 1579 @node Usepackage cheker, Changing mode of YaTeX, Intelligent newline, Top
yuuji@79 1580 @comment node-name, next, previous, up
yuuji@79 1581 @chapter 先回りusepackage
yuuji@79 1582 @cindex 先回りusepackage[さきまわり]
yuuji@79 1583
yuuji@79 1584 begin型、section型、maketitle型、いずれかのLaTeX2eマクロを補完入力すると、
yuuji@79 1585 そのマクロの利用に外部パッケージを必要とする場合、そのパッケージを
yuuji@79 1586 本文中で @code{\usepackage@{@}} しているかどうかを調査し、もししていなければ
yuuji@79 1587 プリアンブルに対応するパッケージを引数にした @code{\usepackage} 文を
yuuji@79 1588 (確認後に)挿入します。
yuuji@79 1589
yuuji@79 1590 ただしこの機能が働くためには、パッケージ名とその中で定義されているマクロ
yuuji@79 1591 群をalistの形式で変数 @code{YaTeX-package-alist-private} に設定しておく必
yuuji@79 1592 要があります。
yuuji@79 1593
yuuji@79 1594 @node Changing mode of YaTeX, Online help, Usepackage cheker, Top
yuuji@73 1595 @comment node-name, next, previous, up
yuuji@73 1596 @chapter 野鳥の動作モード切り替え
yuuji@73 1597 @cindex モード切り替え[もうときりかえ]
yuuji@73 1598 @cindex prefix w
yuuji@73 1599
yuuji@73 1600 @table @kbd
yuuji@73 1601 @item [prefix] w
yuuji@73 1602 @dots{} 野鳥動作モード切り替えメニュー
yuuji@73 1603 @end table
yuuji@73 1604
yuuji@73 1605 @noindent
yuuji@73 1606 で野鳥自身の動作を決定する以下のモードを切り替えます。
yuuji@73 1607
yuuji@73 1608 @itemize @bullet
yuuji@73 1609 @item 修正モード
yuuji@73 1610 @item 野鳥数式モード
yuuji@73 1611 @end itemize
yuuji@73 1612
yuuji@73 1613 修正モードは、開き括弧入力時の処理をコントロールし、修正モードONの時は開き
yuuji@73 1614 括弧の入力は開き括弧のみの入力になり、修正モードOFFの時は開き括弧の入力だ
yuuji@73 1615 けで閉じ括弧まで入力します。デフォルト(起動時)の設定は@emph{OFF}です。
yuuji@73 1616
yuuji@73 1617 野鳥数式モードは、変数 @code{YaTeX-auto-math-mode} が @code{nil} の時の
yuuji@73 1618 み有効で、このとき@kbd{;}や@kbd{:}を押した時(@ref{Image completion}参照)に、
yuuji@73 1619 どのようなイメージ補完を機能させるか、通常のキーとして機能させるかを手動で
yuuji@73 1620 切り替えます。自動判定が遅いマシンでは@code{YaTeX-auto-math-mode}
yuuji@73 1621 @code{nil}にセットし、野鳥数式モードを手動で切り替えると良いでしょう。
yuuji@73 1622
yuuji@73 1623
yuuji@73 1624 @node Online help, Inclusion hierarchy browser, Changing mode of YaTeX, Top
yuuji@73 1625 @comment node-name, next, previous, up
yuuji@73 1626 @chapter オンラインヘルプ
yuuji@73 1627 @cindex オンラインヘルプ[おんらいんへるふ]
yuuji@73 1628 @cindex apropos
yuuji@73 1629 @cindex キーワード検索[きいわあとけんさく]
yuuji@73 1630 @cindex prefix ?
yuuji@73 1631 @cindex prefix /
yuuji@73 1632
yuuji@73 1633 使おうとする La@TeX{} コマンドの用法がよく分からない時は、オンラインヘル
yuuji@73 1634 プをひきましょう。ヘルプに関するキーには以下のものがあります。
yuuji@73 1635
yuuji@73 1636 @table @kbd
yuuji@73 1637 @item [prefix] ?
yuuji@73 1638 @dots{} オンラインヘルプ
yuuji@73 1639 @item [prefix] /
yuuji@73 1640 @dots{} オンラインapropos
yuuji@73 1641 @end table
yuuji@73 1642
yuuji@73 1643 @section オンラインヘルプ
yuuji@73 1644 @cindex グローバルヘルプ[くろおはるへるふ]
yuuji@73 1645 @cindex プライベートヘルプ[ふらいへえとへるふ]
yuuji@73 1646 @cindex YaTeX-help-file
yuuji@73 1647 @cindex YaTeX-help-file-private
yuuji@73 1648
yuuji@73 1649 「オンラインヘルプ」は、一般的な La@TeX{} コマンド(デフォルトでカーソル
yuuji@73 1650 位置のコマンド)に対する説明を隣のバッファに表示します。この時参照されるヘ
yuuji@73 1651 ルプ用ファイルには「グローバルヘルプ」と「プライベートヘルプ」の二種類があ
yuuji@73 1652 り、前者は La@TeX{} の標準コマンドの主なものの説明を含むファイルで、変数
yuuji@73 1653 @code{YaTeX-help-file}の値で指定されます。このファイルは通常公共の場所(デ
yuuji@73 1654 フォルトで@code{$EMACSEXECPATH})に置かれ、誰もがその内容を更新できるように
yuuji@73 1655 全員に書き込み権が与えられるべきものです。後者は、非標準もしくは個人的なマ
yuuji@73 1656 クロ定義に関する説明が書かれているファイルで、変数
yuuji@73 1657 @code{YaTeX-help-file-private}の値で指定されます。こちらはユーザのホームディ
yuuji@73 1658 レクトリの下などに置かれます。
yuuji@73 1659
yuuji@73 1660 @section オンラインapropos
yuuji@73 1661
yuuji@73 1662 「オンラインapropos」は GNU Emacs の apropos と同様、ユーザが指定したキー
yuuji@73 1663 ワードを説明文に含む項目すべてを隣のバッファに表示します。
yuuji@73 1664
yuuji@73 1665 もし、調べようとしたLa@TeX{}コマンドに対する説明がヘルプファイル中に見つ
yuuji@73 1666 からなかった場合は、説明文の入力を求めてくるので、可能であれば参考書などを
yuuji@73 1667 調べてそのコマンドの説明を入力してください。もし、なにか標準的なコマンドに
yuuji@73 1668 対する説明を書いたならばぜひ私までその説明をお送り下さい。次回の配布に含め
yuuji@73 1669 たいと思います。
yuuji@73 1670
yuuji@73 1671 @node Inclusion hierarchy browser, Cooperation with other packages, Online help, Top
yuuji@73 1672 @comment node-name, next, previous, up
yuuji@73 1673 @chapter インクルード構造ブラウザ
yuuji@73 1674 @cindex インクルード構造[いんくるうとこうそう]
yuuji@73 1675 @cindex prefix d
yuuji@73 1676
yuuji@73 1677 複数のファイルに分割しているドキュメントを書いている場合、
yuuji@73 1678
yuuji@73 1679 @table @kbd
yuuji@73 1680 @item [prefix] d
yuuji@73 1681 @dots{} インクルード構造ブラウズ
yuuji@73 1682 @end table
yuuji@73 1683
yuuji@73 1684 @noindent
yuuji@73 1685 を押すと、そのドキュメントの親ファイルを聞いて来ます。ここで全てのファイル
yuuji@73 1686 の親となるファイル(デフォルトが示されているので大抵はRETのみ)を入力すると
yuuji@73 1687 インクルードしている全てのファイルを解析し、インクルード状況を視覚的に表示
yuuji@73 1688 します。このバッファでは以下のキー操作が有効です。
yuuji@73 1689
yuuji@73 1690 @table @kbd
yuuji@73 1691 @item n
yuuji@73 1692 @dots{} 次の行に移動し対応するファイルを隣のバッファに表示
yuuji@73 1693 @item p
yuuji@73 1694 @dots{} 上の行に移動し対応するファイルを隣のバッファに表示
yuuji@73 1695 @item N
yuuji@73 1696 @dots{} 同じインクルードレベルの次のファイルに移動
yuuji@73 1697 @item P
yuuji@73 1698 @dots{} 同じインクルードレベルの前のファイルに移動
yuuji@73 1699 @item j
yuuji@73 1700 @dots{} 次の行に移動
yuuji@73 1701 @item k
yuuji@73 1702 @dots{} 上の行に移動
yuuji@73 1703 @item u
yuuji@73 1704 @dots{} 一代親にあたるファイルに移動
yuuji@73 1705 @item .
yuuji@73 1706 @dots{} カーソル位置のファイルを隣のバッファに表示
yuuji@73 1707 @item SPC
yuuji@73 1708 @dots{} 隣のバッファの対応ファイルをスクロールアップ
yuuji@73 1709 @item DEL, b
yuuji@73 1710 @dots{} 隣のバッファの対応ファイルをスクロールダウン
yuuji@73 1711 @item <
yuuji@73 1712 @dots{} 隣のバッファの対応ファイルの先頭を表示
yuuji@73 1713 @item >
yuuji@73 1714 @dots{} 隣のバッファの対応ファイルの末尾を表示
yuuji@73 1715 @item '
yuuji@73 1716 @dots{} (@kbd{<}や@kbd{>}の後で)元の表示位置に戻る
yuuji@73 1717 @item RET, g
yuuji@73 1718 @dots{} カーソル位置のファイルを隣のバッファでオープン
yuuji@73 1719 @item mouse-2
yuuji@73 1720 @dots{} RETと同じ(ウィンドウ使用時のみ)
yuuji@73 1721 @item o
yuuji@73 1722 @dots{} 隣のウィンドウに移動
yuuji@73 1723 @item 1
yuuji@73 1724 @dots{} 他のウィンドウを消す
yuuji@73 1725 @item -
yuuji@73 1726 @dots{} ブラウズウィンドウを小さくする
yuuji@73 1727 @item +
yuuji@73 1728 @dots{} ブラウズウィンドウを大きくする
yuuji@73 1729 @item ?
yuuji@73 1730 @dots{} ヘルプ表示
yuuji@73 1731 @item q
yuuji@73 1732 @dots{} 表示前の状態に戻る
yuuji@73 1733 @end table
yuuji@73 1734
yuuji@73 1735 ただし、隣のウィンドウのファイルの内容を表示する機能に関しては、対応する
yuuji@73 1736 ファイルをクローズしてしまうとうまく働きませんのでご注意ください。
yuuji@73 1737
yuuji@73 1738 @node Cooperation with other packages, Customizations, Inclusion hierarchy browser, Top
yuuji@73 1739 @comment node-name, next, previous, up
yuuji@73 1740 @chapter 他パッケージとの連携
yuuji@73 1741 @cindex 他パッケージとの連携[たはつけえしとのれんけい]
yuuji@73 1742
yuuji@73 1743 @section gmhist
yuuji@73 1744 @cindex gmhist
yuuji@73 1745 @cindex コマンドヒストリ[こまんとひすとり]
yuuji@73 1746 @cindex ヒストリ[ひすとり]
yuuji@73 1747
yuuji@73 1748 @file{gmhist.el}と@file{gmhist-mh.el} をロードしている場合、プレヴューコ
yuuji@73 1749 マンドの入力(@kbd{[prefix] tp]})、印刷コマンドの入力(@kbd{[prefix] tl})の
yuuji@73 1750 時に独立したヒストリを利用できます。それぞれのプロンプトで、@kbd{M-p} を押
yuuji@73 1751 すと直前に利用したコマンド文字列をくり返し呼び出すことができます。
yuuji@73 1752
yuuji@73 1753 @section min-out
yuuji@73 1754 @cindex min-out
yuuji@73 1755
yuuji@73 1756 @file{min-out.el} (@code{outline-minor-mode}) と野鳥を組み合わせて使うこ
yuuji@73 1757 とももちろん可能です。設定の方法に関しては@file{yatexm-o.el}をご覧ください。
yuuji@73 1758
yuuji@73 1759 @node Customizations, Etc, Cooperation with other packages, Top
yuuji@73 1760 @comment node-name, next, previous, up
yuuji@73 1761 @chapter カスタマイズ
yuuji@73 1762 @cindex カスタマイズ[かすたまいす]
yuuji@73 1763 @cindex キーアサイン[きいあさいん]
yuuji@73 1764
yuuji@73 1765 野鳥の動作を制御する種々の変数を独自に設定することにより、補完入
yuuji@73 1766 力を起動するキーアサインを変えたり、環境名の補完候補をさらに充実さ
yuuji@73 1767 せることなどができます。
yuuji@73 1768
yuuji@73 1769 @menu
yuuji@73 1770 * Lisp variables:: lisp 変数
yuuji@73 1771 * Add-in functions:: 付加関数(アドイン関数)
yuuji@73 1772 @end menu
yuuji@73 1773
yuuji@73 1774 @node Lisp variables, Add-in functions, Customizations, Customizations
yuuji@73 1775 @comment node-name, next, previous, up
yuuji@73 1776 @section lisp 変数
yuuji@73 1777 @cindex prefixキー変更[prefixきいへんこう]
yuuji@73 1778
yuuji@73 1779 例えば prefix キーを @kbd{C-c} 以外のキーにしたい場合は、
yuuji@73 1780 @code{YaTeX-prefix}に prefix キーにしたいシンボルを定義してください。さら
yuuji@73 1781 に、「@kbd{C-c 英字}」というキーバインドは独自の関数が割り当ててあるので使
yuuji@73 1782 いたくない。このような時は、@code{YaTeX-inhibit-prefix-letter} を @code{t}
yuuji@73 1783 に設定することにより、@kbd{C-c 英字…}のバインドが全て、対応する@kbd{C-c
yuuji@73 1784 C-英字…}に変わります(ただし、begin型 large型補完の大文字起動によるリジョ
yuuji@73 1785 ン指定は可能なままです。これも無効にしたい場合は@code{t}ではなく 1 にセッ
yuuji@73 1786 トして下さい。)。
yuuji@73 1787
yuuji@73 1788 @menu
yuuji@73 1789 * All customizable variables:: カスタマイズ変数一覧
yuuji@73 1790 * Sample definitions:: カスタマイズ変数設定例
yuuji@73 1791 * Hook variables:: hook変数
yuuji@73 1792 * Hook file:: hook用ファイル
yuuji@73 1793 @end menu
yuuji@73 1794
yuuji@73 1795 @node All customizable variables, Sample definitions, Lisp variables, Lisp variables
yuuji@73 1796 @comment node-name, next, previous, up
yuuji@73 1797 @subsection カスタマイズ変数一覧
yuuji@73 1798 @cindex カスタマイズ変数一覧[かすたまいすへんすういちらん]
yuuji@73 1799
yuuji@73 1800 yatex-mode における次の変数がカスタマイズ可能です。@file{~/.emacs} で
yuuji@73 1801 @code{setq} しておけば、そちらの定義が優先されます。括弧の中はデフォルト値
yuuji@73 1802 です。実際に変数の値を変更する場合は @kbd{M-x describe-variable} で
yuuji@73 1803 変数の詳細な説明を参照してください。
yuuji@73 1804
yuuji@73 1805 @defvar YaTeX-prefix
yuuji@73 1806 yatex-mode 中のプリフィクスキー (@kbd{\C-c})
yuuji@73 1807 @end defvar
yuuji@73 1808
yuuji@73 1809 @defvar YaTeX-inhibit-prefix-letter
yuuji@73 1810 prefix キーの直後のキーバインドで @kbd{英字} のものを @kbd{C-英字} に変更
yuuji@73 1811 (@code{nil})
yuuji@73 1812 @end defvar
yuuji@73 1813
yuuji@73 1814 @defvar YaTeX-fill-prefix
yuuji@73 1815 本文を書く時の行頭に挿入する接頭辞すなわち fill-prefix (@code{""(nil)})
yuuji@73 1816 @end defvar
yuuji@73 1817
yuuji@73 1818 @defvar YaTeX-user-completion-table
yuuji@73 1819 学習したLa@TeX{}コマンド保存ファイル名 (@code{"~/.yatexrc"})
yuuji@73 1820 @end defvar
yuuji@73 1821
yuuji@73 1822 @defvar YaTeX-kanji-code
yuuji@79 1823 文書を作成する時の漢字コード
yuuji@79 1824 nil=既存のコードのまま 0=no-conversion1=Shift JIS,
yuuji@79 1825 2=JIS, 3=EUC (2 (MS-DOSでは1))
yuuji@73 1826 @end defvar
yuuji@73 1827
yuuji@73 1828 @defvar tex-command
yuuji@73 1829 La@TeX{}タイプセッタコマンド名 (@code{"platex"})
yuuji@73 1830 @end defvar
yuuji@73 1831
yuuji@73 1832 @defvar dvi2-command
yuuji@73 1833 プレヴューアコマンド名 (@code{"xdvi -geo +0+0 -s 4"})
yuuji@73 1834 @end defvar
yuuji@73 1835
yuuji@73 1836 @defvar dviprint-command-format
yuuji@73 1837 dviファイルの印刷に使われるコマンド式 (@code{"dvi2ps %f %t %s | lpr"})
yuuji@73 1838 @end defvar
yuuji@73 1839
yuuji@73 1840 @defvar dviprint-from-format
yuuji@73 1841 上の@code{%f}に相当する開始ページ指定書式、@code{%b} が開始ページ番号に変
yuuji@73 1842 わる (@code{"-f %b"})
yuuji@73 1843 @end defvar
yuuji@73 1844
yuuji@73 1845 @defvar dviprint-to-format
yuuji@73 1846 @code{%t} に相当する終了ページ指定書式、@code{%e}が終了ページ番号に変わる
yuuji@73 1847 (@code{"-t %e"})
yuuji@73 1848 @end defvar
yuuji@73 1849
yuuji@73 1850 @defvar makeindex-command
yuuji@73 1851 makeindexコマンド (@code{"makeindex"} (MS-DOSでは@code{"makeind"}))
yuuji@73 1852 @end defvar
yuuji@73 1853
yuuji@73 1854 @defvar YaTeX-need-nonstop
yuuji@73 1855 @code{\nonstopmode@{@}}を自動的に付加するか (@code{nil})
yuuji@73 1856 @end defvar
yuuji@73 1857
yuuji@73 1858 @defvar latex-warning-regexp
yuuji@73 1859 latexコマンドの出力するウォーニング行の正規表現 (@code{"line.* [0-9]*"})
yuuji@73 1860 @end defvar
yuuji@73 1861
yuuji@73 1862 @defvar latex-error-regexp
yuuji@73 1863 同じくエラー行の正規表現 (@code{"l\\.[1-9][0-9]*"})
yuuji@73 1864 @end defvar
yuuji@73 1865
yuuji@73 1866 @defvar latex-dos-emergency-message
yuuji@73 1867 MS-DOS上で動作する latex コマンドが、エラーにより停止するとき出力するメッ
yuuji@73 1868 セージ (@code{"Emergency stop"})
yuuji@73 1869 @end defvar
yuuji@73 1870
yuuji@73 1871 @defvar latex-message-kanji-code
yuuji@73 1872 タイプセッタの出力するメッセージの漢字コード.タイプセットバッファ
yuuji@73 1873 の出力が化ける時は、これを設定する (2, Nemacsでのみ有効)
yuuji@73 1874 @end defvar
yuuji@73 1875
yuuji@73 1876 @defvar NTT-jTeX
yuuji@73 1877 古いNTT-j@TeX{}使用時のようにインデントした行の先頭と前の行の
yuuji@73 1878 (タイプセット後の)字間が空いてしまうのを嫌う場合は@code{t}にする
yuuji@73 1879 (@code{nil})
yuuji@73 1880 @end defvar
yuuji@73 1881
yuuji@73 1882 @defvar YaTeX-item-regexp
yuuji@73 1883 itemの桁揃えの時に用いる、itemの正規表現 (@code{"\\\\(sub\\)*item"})
yuuji@73 1884 @end defvar
yuuji@73 1885
yuuji@73 1886 @defvar YaTeX-verb-regexp
yuuji@73 1887 verbコマンドの正規表現。先頭の\\\\はつけない (@code{"verb\\*?\\|path"})
yuuji@73 1888 @end defvar
yuuji@73 1889
yuuji@73 1890 @defvar YaTeX-nervous
yuuji@73 1891 ローカル辞書を用いる時 @code{t} (@code{t})
yuuji@73 1892 @end defvar
yuuji@73 1893
yuuji@73 1894 @defvar YaTeX-sectioning-regexp
yuuji@73 1895 セクション区切り設定コマンドの正規表現
yuuji@73 1896 (@code{"\\(part\\|chapter\\*?\\|\\(sub\\)*\\(section\\|paragraph\\)\\*?\\)\\b"})
yuuji@73 1897 @end defvar
yuuji@73 1898
yuuji@73 1899 @defvar YaTeX-fill-inhibit-environments
yuuji@73 1900 fill を抑止する環境名のリスト
yuuji@73 1901 (@code{'("tabular" "tabular*" "array" "picture" "eqnarray" "eqnarray*" "equation" "math" "displaymath" "verbatim" "verbatim*")})
yuuji@73 1902 @end defvar
yuuji@73 1903
yuuji@73 1904 @defvar YaTeX-uncomment-once
yuuji@73 1905 領域uncommentで行頭の複数の@code{%}を全て削除するか (@code{nil})
yuuji@73 1906 @end defvar
yuuji@73 1907
yuuji@73 1908 @defvar YaTeX-close-paren-always
yuuji@73 1909 開き括弧の入力で常に閉じ括弧を入力する (@code{t})
yuuji@73 1910 @end defvar
yuuji@73 1911
yuuji@73 1912 @defvar YaTeX-auto-math-mode
yuuji@73 1913 数式モードの切り替えを自動的に行う (@code{t})
yuuji@73 1914 @end defvar
yuuji@73 1915
yuuji@73 1916 @defvar YaTeX-math-key-list-private
yuuji@73 1917 数式イメージ補完で用いる (プリフィクスキー . 対応補完テーブル) の
yuuji@73 1918 alist (@code{nil})。補完テーブルの書き方については@file{yatexmth.el}を参照。
yuuji@73 1919 @end defvar
yuuji@73 1920
yuuji@73 1921 @defvar YaTeX-default-pop-window-height
yuuji@73 1922 1画面の時にタイプセットバッファを初めて作成する時の高さ。数値で行数、数字
yuuji@73 1923 文字列でEmacsウィンドウに対する百分率 (10)
yuuji@73 1924 @end defvar
yuuji@73 1925
yuuji@73 1926 @defvar YaTeX-help-file
yuuji@73 1927 共用ヘルプファイル (@file{$doc-directory/../../site-lisp/YATEXHLP.jp})
yuuji@73 1928 @end defvar
yuuji@73 1929
yuuji@73 1930 @defvar YaTeX-help-file-private
yuuji@73 1931 個人用ヘルプファイル (@file{"~/YATEXHLP.jp"})
yuuji@73 1932 @end defvar
yuuji@73 1933
yuuji@73 1934 @defvar YaTeX-no-begend-shortcut
yuuji@73 1935 @kbd{[prefix] b ??} のショートカットを使わず、@kbd{[prefix] b} だけで補完
yuuji@73 1936 入力に入る (@code{nil})
yuuji@73 1937 @end defvar
yuuji@73 1938
yuuji@73 1939 @defvar YaTeX-hilit-pattern-adjustment-private
yuuji@73 1940 正規表現とそれにマッチするものの論理的意味をシンボルであらわしたものの
yuuji@73 1941 リスト…のリスト。hilit19 を組み込んでいる時のみ有効。
yuuji@73 1942 詳しくは @code{(assq 'yatex-mode hilit-patterns-alist)}
yuuji@73 1943 した結果と、変数 @code{YaTeX-hilit-pattern-adjustment-default} の値(と場合
yuuji@73 1944 によっては hilit19 のドキュメント)を参照せよ。
yuuji@73 1945 @end defvar
yuuji@73 1946
yuuji@73 1947 @defvar YaTeX-sectioning-level
yuuji@73 1948 LaTeXのセクション単位宣言コマンドとその論理的高さのalist。
yuuji@73 1949 @end defvar
yuuji@73 1950
yuuji@73 1951 @defvar YaTeX-hierarchy-ignore-heading-regexp
yuuji@73 1952 Hierarchy バッファは通常ファイルヘッダとして、LaTeXのセクション宣言コマン
yuuji@73 1953 ドの引数を検索し、それがなければコメント行を探すが、その際にヘッダとしては
yuuji@73 1954 意味を持たないパターンをこの変数に設定する。デフォルトでは RCS ヘッダとモー
yuuji@73 1955 ド指定行(-*- xxx -*-)が設定されている。
yuuji@73 1956 @end defvar
yuuji@73 1957
yuuji@73 1958 @defvar YaTeX-skip-default-reader
yuuji@73 1959 Non-nil に設定するとsection型コマンドの引数入力時、アドイン関数がなければ
yuuji@73 1960 ミニバッファでの読み込みをせずに入力を完了させる (@code{nil})
yuuji@73 1961 @end defvar
yuuji@73 1962
yuuji@73 1963 @defvar YaTeX-create-file-prefix-g
yuuji@73 1964 @code{\include}などで @kbd{prefix g}した時に、ジャンプ先が存在しないファイ
yuuji@73 1965 ルであってもオープンする (@code{nil})
yuuji@73 1966 @end defvar
yuuji@73 1967
yuuji@73 1968 @defvar YaTeX-simple-messages
yuuji@73 1969 各種補完時のメッセージ出力を簡素化する (@code{nil})
yuuji@73 1970 @end defvar
yuuji@73 1971
yuuji@73 1972 @defvar YaTeX-hilit-sectioning-face
yuuji@73 1973 色付けが有効な時の @code{\part} の色
yuuji@73 1974 (@code{'(yellow/dodgerblue yellow/slateblue)})。
yuuji@73 1975 リストの第一要素は @code{hilit-background-mode} が @code{'light} の時の、
yuuji@73 1976 第二要素は @code{'dark} の時の @code{\chapter} の色で、文字色/背景色 のよ
yuuji@73 1977 うに指定する。
yuuji@73 1978 @end defvar
yuuji@73 1979
yuuji@73 1980 @defvar YaTeX-hilit-sectioning-attenuation-rate
yuuji@73 1981 色付けが有効な時の、@code{\subparagraph} の色を @code{\chapter} の濃度の何
yuuji@73 1982 %薄くしたものにするか (@code{'(15 40)}) @code{YaTeX-hilit-sectioning-face}
yuuji@73 1983 の項参照。
yuuji@73 1984 @end defvar
yuuji@73 1985
yuuji@73 1986 @defvar YaTeX-use-AMS-LaTeX
yuuji@73 1987 AMS-LaTeX を使用する場合は @code{t} に設定する (@code{nil})
yuuji@73 1988 @end defvar
yuuji@73 1989
yuuji@73 1990 @defvar YaTeX-use-LaTeX2e
yuuji@73 1991 LaTeX2e を使用する場合は @code{t} に設定する (@code{t})
yuuji@73 1992 @end defvar
yuuji@73 1993
yuuji@73 1994 @defvar YaTeX-template-file
yuuji@73 1995 新規ファイル作成時に自動挿入するファイル名 (@code{~/work/template.tex})
yuuji@73 1996 @end defvar
yuuji@73 1997
yuuji@73 1998 @defvar YaTeX-search-file-from-top-directory
yuuji@73 1999 inputするファイルを探すときの基準ディレクトリをmainファイルのあるディレクト
yuuji@73 2000 リにするか (@code{t})
yuuji@73 2001 @end defvar
yuuji@73 2002 @defvar YaTeX-use-font-lock
yuuji@73 2003 ソースの色づけパッケージとして font-lock を利用するかどうか
yuuji@73 2004 (@code{(featurep 'font-lock)})
yuuji@73 2005 @end defvar
yuuji@73 2006
yuuji@73 2007 @defvar YaTeX-use-hilit19
yuuji@73 2008 ソースの色づけパッケージとして hilit19 を利用するかどうか
yuuji@73 2009 (@code{(featurep 'hilit19)})
yuuji@73 2010 @end defvar
yuuji@73 2011
yuuji@73 2012 @defvar YaTeX-use-italic-bold
yuuji@73 2013 italic, boldフォントを野鳥が探すかどうか (Emacs20以降なら@code{t})
yuuji@73 2014 font-lock利用時のみ有効。
yuuji@73 2015 (@code{(featurep 'hilit19)}
yuuji@73 2016 @end defvar
yuuji@73 2017
yuuji@79 2018 @defvar YaTeX-singlecmd-suffix
yuuji@79 2019 全てのmaketitle型コマンドの補完入力直後に挿入する文字列。
yuuji@79 2020 @code{"{}"} などがお勧め。
yuuji@79 2021 @end defvar
yuuji@79 2022
yuuji@79 2023 @defvar YaTeX-package-alist-private
yuuji@79 2024 LaTeX2eのパッケージ名とその中に含まれるマクロのリスト。
yuuji@79 2025 適切に設定しておくと本文入力時にマクロを補完入力すると
yuuji@79 2026 そのマクロに必要なパッケージを usepackage するか自動的に検査してくれる。
yuuji@79 2027 していなければ \usepackage を自動追加することもできる。
yuuji@79 2028 リストは
yuuji@79 2029 @lisp
yuuji@79 2030 '((パッケージ名1
yuuji@79 2031 (補完タイプ マクロのリスト……)
yuuji@79 2032 (補完タイプ マクロのリスト……))
yuuji@79 2033 (パッケージ名2
yuuji@79 2034 (補完タイプ マクロのリスト……)
yuuji@79 2035 (補完タイプ マクロのリスト……))………)
yuuji@79 2036 @end lisp
yuuji@79 2037 という形式にする。補完タイプは @code{env, section, maketitle} のどれか。
yuuji@79 2038 具体例は変数 @code{YaTeX-package-alist-default}
yuuji@79 2039 の値参照。
yuuji@79 2040 @end defvar
yuuji@79 2041
yuuji@80 2042 @defvar YaTeX-tabular-indentation
yuuji@80 2043 tabular/array 環境で現在行の先頭位置が表の第Nカラムのときは
yuuji@80 2044 標準インデント位置から N*YaTeX-tabular-indentation 桁下げた
yuuji@80 2045 インデントにする。
yuuji@80 2046 @end defvar
yuuji@80 2047
yuuji@80 2048 @defvar YaTeX-noindent-env-regexp
yuuji@80 2049 別の環境内にあっても \begin{} が行頭から始まるべき環境名の正規表現。
yuuji@80 2050 verbatim環境などを指定する。
yuuji@80 2051 @end defvar
yuuji@80 2052
yuuji@80 2053 @defvar YaTeX-ref-default-label-string
yuuji@80 2054 \ref{} のラベル補完でラベル未設定のものに自動的に生成する
yuuji@80 2055 ラベル名の書式。strftime(3)関数に似た日付ベースで指定する。
yuuji@80 2056 利用できる書式は以下のとおり。
yuuji@80 2057 %y -> 西暦下二桁, %b -> 月の英名, %m -> 月(1〜12)
yuuji@80 2058 %d -> 日, %H -> 時, %M -> 分, %S -> 秒,
yuuji@80 2059 %qx -> アルファベットで26進数化した yymmdd.
yuuji@80 2060 %qX -> アルファベットで26進数化した HHMMSS.
yuuji@80 2061 デフォルトは "%H%M%S_%d%b%y"
yuuji@80 2062 @end defvar
yuuji@80 2063
yuuji@80 2064 @defvar YaTeX-ref-generate-label-function
yuuji@80 2065 \ref{}のラベル名自動生成のときに使う関数のシンボル。
yuuji@80 2066 デフォルトは標準の YaTeX::ref-generate-label 関数が割り当ててある。
yuuji@80 2067 引数を2つ取る関数を定義して、この変数にセットするとその関数を呼んだ
yuuji@80 2068 結果をデフォルトのラベル名候補とする。設定例:
yuuji@80 2069 @lisp
yuuji@80 2070 (setq YaTeX-ref-generate-label-function 'my-yatex-generate-label)
yuuji@80 2071 (defun my-yatex-generate-label (command value)
yuuji@80 2072 (and (string= command "caption")
yuuji@80 2073 (re-search-backward "\\\\begin{\\(figure\\|table\\)}" nil t)
yuuji@80 2074 (setq command (match-string 1)))
yuuji@80 2075 (let ((alist '(("chapter" . "chap")
yuuji@80 2076 ("section" . "sec")
yuuji@80 2077 ("subsection" . "subsec")
yuuji@80 2078 ("figure" . "fig")
yuuji@80 2079 ("table" . "tbl"))))
yuuji@80 2080 (if (setq command (cdr (assoc command alist)))
yuuji@80 2081 (concat command ":" value)
yuuji@80 2082 (YaTeX::ref-generate-label nil nil))))
yuuji@80 2083 @end lisp
yuuji@80 2084 @end defvar
yuuji@80 2085
yuuji@73 2086 @node Sample definitions, Hook variables, All customizable variables, Lisp variables
yuuji@73 2087 @comment node-name, next, previous, up
yuuji@73 2088 @subsection カスタマイズ変数設定例
yuuji@73 2089 @cindex 設定例[せつていれい]
yuuji@73 2090
yuuji@73 2091 たとえば、prefix キーとして@kbd{ESC}を使用し、新たな補完候補を格納するファ
yuuji@73 2092 イルを、@file{~/src/emacs/yatexrc} にし、行頭の prefix をタブ文字一つに変
yuuji@73 2093 えたいときは、
yuuji@73 2094
yuuji@73 2095 @lisp
yuuji@73 2096 (setq YaTeX-prefix "\e"
yuuji@73 2097 YaTeX-user-completion-table "~/src/emacs/yatexrc"
yuuji@73 2098 YaTeX-fill-prefix " ")
yuuji@73 2099 @end lisp
yuuji@73 2100
yuuji@73 2101 @noindent
yuuji@73 2102 を @file{~/.emacs} に加えます。
yuuji@73 2103
yuuji@73 2104 @node Hook variables, Hook file, Sample definitions, Lisp variables
yuuji@73 2105 @comment node-name, next, previous, up
yuuji@73 2106 @subsection hook変数
yuuji@73 2107 @cindex hook変数[hookへんすう]
yuuji@73 2108 @cindex yatex-mode-hook
yuuji@73 2109 @cindex yatex-mode-load-hook
yuuji@73 2110
yuuji@73 2111 また、hook 変数 @code{yatex-mode-hook}, @code{yatex-mode-load-hook} を用
yuuji@73 2112 意しています。すべての yatex-mode のバッファで作用させたいものは、
yuuji@73 2113 @code{yatex-mode-hook} に記述し、@file{yatex.el} をロードする時だけ作用さ
yuuji@73 2114 せたいものは@code{yatex-mode-load-hook} に記述します。例えば、
yuuji@73 2115 @code{outline-minor-mode} を利用する場合、それぞれのバッファで
yuuji@73 2116 @code{outline-minor-mode} を有効にしたいので、@code{yatex-mode-hook} を次
yuuji@73 2117 のように設定します。
yuuji@73 2118
yuuji@73 2119 @lisp
yuuji@73 2120 (setq yatex-mode-hook
yuuji@73 2121 '(lambda () (outline-minor-mode t)))
yuuji@73 2122 @end lisp
yuuji@73 2123
yuuji@73 2124 @noindent
yuuji@73 2125 逆に、独自のキー定義を行いたい時などは、@code{yatex-mode-load-hook} を利用
yuuji@73 2126 します。例えば、begin 型補完において、 document や、enumerate 以外の環境名
yuuji@73 2127 もショートカットキーで入れたいなどという時は、次のようにします。以下の例は、
yuuji@73 2128 @kbd{[prefix] ba} で @code{\begin@{abstract@}}, @code{\end@{abstract@}} を
yuuji@73 2129 挿入します。
yuuji@73 2130
yuuji@73 2131 @lisp
yuuji@73 2132 (setq yatex-mode-load-hook
yuuji@73 2133 '(lambda() (YaTeX-define-begend-key "ba" "abstract")))
yuuji@73 2134 @end lisp
yuuji@73 2135
yuuji@73 2136 なお、新たなキーの定義には、関数 @code{YaTeX-define-key}
yuuji@73 2137 @code{YaTeX-define-begend-key}を利用するようにしてください。
yuuji@73 2138
yuuji@73 2139 @node Hook file, , Hook variables, Lisp variables
yuuji@73 2140 @comment node-name, next, previous, up
yuuji@73 2141 @subsection hook用ファイル
yuuji@73 2142
yuuji@73 2143 変数 @code{yatex-mode-load-hook} で定義する内容が多い時は、
yuuji@73 2144 @file{yatexhks.el}というファイルを作り、その中に野鳥関連の設定を書く事で、
yuuji@73 2145 初期化の時に自動的にロードします。
yuuji@73 2146
yuuji@73 2147
yuuji@73 2148 @node Add-in functions, , Lisp variables, Customizations
yuuji@73 2149 @comment node-name, next, previous, up
yuuji@73 2150 @section 付加関数(アドイン関数)
yuuji@73 2151
yuuji@73 2152 各種補完時に、環境名やコマンド名に応じたきめ細やかな補完入力機能を実現す
yuuji@73 2153 るための関数を作成することができます。この関数の作成方法や、組み込み方法に
yuuji@73 2154 関しては、@code{yatexadd.doc} をご覧ください。
yuuji@73 2155
yuuji@73 2156 @node Etc, Copying, Customizations, Top
yuuji@73 2157 @comment node-name, next, previous, up
yuuji@73 2158 @chapter その他
yuuji@73 2159
yuuji@73 2160 野鳥の標準の La@TeX{} コマンドの辞書には、作者が頻繁に使うものしか登録さ
yuuji@73 2161 れていません。これは、補完候補に使いそうもないコマンドが存在して、補完した
yuuji@73 2162 いコマンドを出すまでのストローク数を増やしてしまう事を防止するためです。標
yuuji@73 2163 準辞書にないコマンドも、できるだけ補完入力方式を利用し、ユーザ辞書を充実さ
yuuji@73 2164 せることで、あなたの La@TeX{} スタイルにあった野鳥へと育っていくことでしょ
yuuji@73 2165 う。
yuuji@73 2166
yuuji@73 2167 @node Copying, Concept Index, Etc, Top
yuuji@73 2168 @comment node-name, next, previous, up
yuuji@73 2169 @chapter 取り扱い
yuuji@73 2170
yuuji@73 2171 本プログラムはフリーソフトウェアです。本プログラムを使用して生じたいかな
yuuji@73 2172 る結果に対しても作者は責任を負わないこととします。転載等に関しては制限いた
yuuji@80 2173 しません。常識的に扱ってください。また、本プログラムに含まれるコードを利用
yuuji@80 2174 すること、改造することも自由に行なって構いませんが、流用することにより契約
yuuji@80 2175 締結の必要が生じる場合、私はいかなる契約も締結しません。具体的にはGPLへの
yuuji@80 2176 サインはしませんので、GNUに寄贈するものを作っている場合私の作品から取り込
yuuji@80 2177 んだコードを流用すると苦労するかもしれません。いかなるコード流用も拒否しま
yuuji@80 2178 せんが契約締結は辞退します。
yuuji@73 2179
yuuji@73 2180 苦情、希望、バグ報告、感想等は歓迎いたします。
yuuji@80 2181 連絡は yuuji@@yatex.org まで(2004年1月現在)。
yuuji@73 2182 継続的に使用してくださる方はメイリングリスト「fj野鳥の会」に
yuuji@73 2183 是非加入してください。加入方法については本パッケージの @file{docs/qanda}
yuuji@73 2184 ファイルの「その他」の章を御覧ください。
yuuji@73 2185
yuuji@73 2186 仕様は、予告なく確実に(気分次第で)変更されます:-p。
yuuji@73 2187
yuuji@73 2188 @flushright
yuuji@73 2189 広瀬雄二
yuuji@73 2190 @end flushright
yuuji@73 2191
yuuji@73 2192 @node Concept Index, , Copying, Top
yuuji@73 2193 @comment node-name, next, previous, up
yuuji@73 2194 @unnumbered 索引
yuuji@73 2195 @printindex cp
yuuji@73 2196
yuuji@73 2197 @c カスタマイズ変数索引を索引と分離する場合にはコメントアウトを外す!!!
yuuji@73 2198 @c @node Variable Index
yuuji@73 2199 @c @comment node-name, next, previous, up
yuuji@73 2200 @c @unnumbered カスタマイズ変数索引
yuuji@73 2201 @c @printindex vr
yuuji@73 2202
yuuji@73 2203 @contents
yuuji@73 2204
yuuji@73 2205 @bye
yuuji@73 2206
yuuji@73 2207 @c Local Variables:
yuuji@73 2208 @c fill-column: 74
yuuji@73 2209 @c fill-prefix: nil
yuuji@73 2210 @c buffer-file-coding-system: sjis-dos
yuuji@73 2211 @c End:
yuuji@73 2212 
yuuji@73 2213 Tag table:
yuuji@73 2214 
yuuji@73 2215 End tag table