annotate yatexmth.el @ 77:1b172d26b55e

Fix auto-fill movement on Emacs21. Fix YaTeX:ref. Support jump/change on AMS-LaTeX's parentheses.
author yuuji
date Thu, 01 May 2003 13:38:27 +0000
parents 0aaebd07dad0
children 9b4354af748c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
1 ;;; -*- Emacs-Lisp -*-
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
2 ;;; YaTeX math-mode-specific functions.
64
36a48185b95a Changes are listed in yatex.new.
yuuji
parents: 60
diff changeset
3 ;;; yatexmth.el
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
4 ;;; (c)1993-2003 by HIROSE Yuuji [yuuji@yatex.org]
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
5 ;;; Last modified Sun Mar 30 19:56:00 2003 on firestorm
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
6 ;;; $Id$
390df0e505da Label completion works.
yuuji
parents:
diff changeset
7
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
8 ;;; [Customization guide]
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
9 ;;;
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
10 ;;; By default, you can use two completion groups in YaTeX math
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
11 ;;; mode, `;' for mathematical signs and `:' for greek letters. But
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
12 ;;; you can add other completion groups by defining the alist of
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
13 ;;; `prefix key' vs `completion list' into the variable
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
14 ;;; YaTeX-math-key-list-private. If you wish to accomplish the
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
15 ;;; completion as follows(prefix key is `,'):
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
16 ;;;
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
17 ;;; KEY COMPLETION
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
18 ;;; s \sin
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
19 ;;; S \arcsin
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
20 ;;; c \cos
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
21 ;;; C \arccos
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
22 ;;; :
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
23 ;;; T \arctan
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
24 ;;; l \log
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
25 ;;; hs \sinh
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
26 ;;;
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
27 ;;; Typing `s' after `,' makes `\sin', `hs' after `,' makes `\sinh'
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
28 ;;; and so on. First, you have to define list of key-completion
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
29 ;;; pairs. Variable name(YaTeX-math-funcs-list) is arbitrary.
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
30 ;;;
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
31 ;;; (setq YaTeX-math-funcs-list
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
32 ;;; '(("s" "sin")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
33 ;;; ("S" "arcsin")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
34 ;;; :
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
35 ;;; ("hs" "sinh")))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
36 ;;;
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
37 ;;; Next, define the list of prefix-key vs completion list(defined
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
38 ;;; above) into the variable YaTeX-math-key-list-private.
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
39 ;;;
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
40 ;;; (setq YaTeX-math-key-list-private
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
41 ;;; '(("," . YaTeX-math-funcs-list)
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
42 ;;; ("'" . Other-List-if-any)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
43 ;;;
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
44 ;;; Put these expressions into your ~/.emacs, and you can use this
51
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
45 ;;; completion in the math-mode.
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
46 ;;;
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
47 ;;; And you can add your favorite completion sequences to the
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
48 ;;; default completion list invoked with `;', by defining those lists
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
49 ;;; into variable YaTeX-math-sign-alist-private.
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
50
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
51 ;;; 【イメージ補完の追加方法】
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
52 ;;;
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
53 ;;; 標準のイメージ補完では、「;」で始まる数式記号補完と、「:」で始
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
54 ;;; まるギリシャ文字補完が使用可能ですが、これ以外の文字で始まる補完
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
55 ;;; シリーズも定義することができます。例えば、「,」で始まる次のよう
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
56 ;;; な補完シリーズを定義する場合を考えてみます。
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
57 ;;;
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
58 ;;; 補完キー 補完結果
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
59 ;;; s \sin
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
60 ;;; S \arcsin
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
61 ;;; c \cos
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
62 ;;; C \arccos
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
63 ;;; :
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
64 ;;; T \arctan
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
65 ;;; l \log
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
66 ;;; hs \sinh
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
67 ;;;
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
68 ;;; 「,」のあとに s を押すと \sin が、hs を押すと \sinh が入力されま
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
69 ;;; す。このような補完リストの登録は以下のようにします(変数名は任意)。
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
70 ;;;
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
71 ;;; (setq YaTeX-math-funcs-list
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
72 ;;; '(("s" "sin")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
73 ;;; ("S" "arcsin")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
74 ;;; :
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
75 ;;; ("hs" "sinh")))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
76 ;;;
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
77 ;;; さらに、「,」を押した時にイメージ補完が始まるよう次の変数に、起動キー
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
78 ;;; と上で定義した補完用変数の登録を行ないます。
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
79 ;;;
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
80 ;;; (setq YaTeX-math-key-list-private
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
81 ;;; '(("," . YaTeX-math-funcs-list)
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
82 ;;; ("'" . ほかに定義したいシリーズがあれば…)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
83 ;;;
51
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
84 ;;; これらを ~/.emacs に書いておけば、math-mode で自分専用のイメージ
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
85 ;;; 補完が利用できます。
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
86
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
87 (defvar YaTeX-jisold
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
88 (and (boundp 'dos-machine-type)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
89 (eq dos-machine-type 'pc98)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
90
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
91 (defmacro YaTeX-setq-math-sym (sym old new)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
92 (list 'setq sym (list 'if 'YaTeX-jisold old new)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
93
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
94 (YaTeX-setq-math-sym YaTeX-image-in "E" "∈")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
95 (YaTeX-setq-math-sym YaTeX-image-ni "ヨ" "∋")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
96 (YaTeX-setq-math-sym YaTeX-image-subset " _\n(\n ~" "⊂")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
97 (YaTeX-setq-math-sym YaTeX-image-subseteq " _\n(_\n ~" "⊆")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
98 (YaTeX-setq-math-sym YaTeX-image-supset "_\n )\n~" "⊃")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
99 (YaTeX-setq-math-sym YaTeX-image-supseteq "_\n_)\n~" "⊇")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
100 (YaTeX-setq-math-sym YaTeX-image-nabla "___\n\\\\/" "∇")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
101 (YaTeX-setq-math-sym YaTeX-image-partial " -+\n+-+\n+-+" "∂")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
102 (YaTeX-setq-math-sym YaTeX-image-dagger "+\n|" "†")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
103 (YaTeX-setq-math-sym YaTeX-image-ddagger "+\n+\n|" "‡")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
104 (YaTeX-setq-math-sym YaTeX-image-equiv "=\n ̄" "≡")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
105 (YaTeX-setq-math-sym YaTeX-image-int " /\\\n \\\n\\/" "∫")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
106 (YaTeX-setq-math-sym YaTeX-image-bot "|\n ̄" "⊥")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
107 (YaTeX-setq-math-sym YaTeX-image-neg "イ" "¬")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
108 (YaTeX-setq-math-sym YaTeX-image-flat "b" "♭")
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
109 (YaTeX-setq-math-sym YaTeX-image-sqrt "" "√")
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
110
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
111 (defvar
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
112 YaTeX-math-sign-alist-default
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
113 '(
390df0e505da Label completion works.
yuuji
parents:
diff changeset
114 ;frequently used
390df0e505da Label completion works.
yuuji
parents:
diff changeset
115 ("||" "|" ("||" "‖"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
116 ("sum" "sum" ("\\-+\n >\n/-+" "Σ"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
117 ("sigma" "sum" ("\\-+\n >\n/-+" "Σ"))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
118 ("integral" "int" (" /\\\n \\\n\\/" YaTeX-image-int))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
119 ("ointegral" "oint" " /\\\n(\\)\n\\/")
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
120 ("sqrt" "sqrt" (" __\n,/" YaTeX-image-sqrt))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
121 ("root" "sqrt" (" __\n,/" YaTeX-image-sqrt))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
122 ("A" "forall" "|_|\nV")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
123 ("E" "exists" "-+\n-+\n-+")
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
124 ("!" "neg" ("--+\n |" YaTeX-image-neg))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
125 ("oo" "infty" ("oo" "∞"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
126 ("\\" "backslash" ("\\" "\"))
68
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
127 ("..." "cdots" ("..." "…"))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
128
390df0e505da Label completion works.
yuuji
parents:
diff changeset
129 ;;binary operators
390df0e505da Label completion works.
yuuji
parents:
diff changeset
130 ("+-" "pm" ("+\n-" "±"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
131 ("-+" "mp" "-\n+")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
132 ("x" "times" ("x" "×"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
133 ("/" "div" (",\n-\n'" "÷"))
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
134 ("f" "frac" "xxx\n---\nyyy" "÷")
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
135 ("*" "ast" "*")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
136 ("#" "star" ("_/\\_\n\\ /\n//\\\\" "★"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
137 ("o" "circ" "o")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
138 ("o*" "bullet" " _\n(*)\n ~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
139 ("." "cdot" ".")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
140 ("cap" "cap" "/-\\\n| |")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
141 ("cup" "cup" "| |\n\\-/")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
142 ("u+" "uplus" "|+|\n\\-/")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
143 ("|~|" "sqcap" "|~|")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
144 ("|_|" "sqcup" "|_|")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
145 ("v" "vee" "v")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
146 ("^" "wedge" "^")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
147 ("\\\\" "setminus" "\\")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
148 (")(" "wr" " )\n(")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
149 ("<>" "diamond" "<>")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
150 ("/\-" "bigtriangleup" ("/\\\n~~" "△"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
151 ("-\\/" "bigtriangledown" ("__\n\\/" "▽"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
152 ("<|" "triangleleft" "<|")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
153 ("|>" "triangleright" "|>")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
154 ("<||" "lhd" "/|\n\\|")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
155 ("||>" "rhd" "|\\\n|/")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
156 ("<|-" "unlhd" "<|\n~~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
157 ("|>-" "unrhd" "|>\n~~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
158 ("o+" "oplus" " _\n(+)\n ~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
159 ("o-" "ominus" " _\n(-)\n ~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
160 ("ox" "otimes" " _\n(x)\n ~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
161 ("o/" "oslash" " _\n(/)\n ~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
162 ("o." "odot" "(.)")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
163 ("O" "bigcirc" "O")
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
164 ("t" "dagger" ("+\n|" YaTeX-image-dagger))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
165 ("tt" "ddagger" ("+\n+\n|" YaTeX-image-ddagger))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
166 ("II" "amalg" "II")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
167 ; :
390df0e505da Label completion works.
yuuji
parents:
diff changeset
168 ;;relational operators
390df0e505da Label completion works.
yuuji
parents:
diff changeset
169 ("<" "leq" ("<\n-" "≦"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
170 (">" "geq" (">\n-" "≧"))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
171 ("-=" "equiv" ("=\n-" YaTeX-image-equiv))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
172 ("=-" "equiv" ("=\n-" YaTeX-image-equiv))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
173 ("---" "equiv" ("=\n-" YaTeX-image-equiv))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
174 ("(" "subset" (" _\n(\n ~" YaTeX-image-subset))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
175 ("(-" "subseteq" (" _\n(_\n ~" YaTeX-image-subseteq))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
176 (")" "supset" ("_\n )\n~" YaTeX-image-supset))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
177 (")-" "supseteq" ("_\n_)\n~" YaTeX-image-supseteq))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
178 ("[" "sqsubset" "[")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
179 ("[-" "sqsubseteq" "[\n~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
180 ("]" "sqsupset" "]")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
181 ("]-" "sqsupseteq" "]\n~")
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
182 ("{" "in" ("(-" YaTeX-image-in))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
183 ("}" "ni" ("-)" YaTeX-image-ni))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
184 ("|-" "vdash" "|-")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
185 ("-|" "dashv" "-|")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
186 ("~" "sim" "~(tild)")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
187 ("~-" "simeq" "~\n-")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
188 ("asymp" "asymp" "v\n^")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
189 ("~~" "approx" "~\n~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
190 ("~=" "cong" "~\n=")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
191 ("=/" "neq" ("=/=" "≠"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
192 (".=" "doteq" ".\n=")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
193 ("o<" "propto" "o<")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
194 ("|=" "models" "|=")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
195 ("_|_" "perp" "_|_")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
196 ("|" "mid" "|")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
197 ("||" "parallel" "||")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
198 ("bowtie" "bowtie" "|><|(wide)")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
199 ("|><|" "join" "|><|")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
200 ("\\_/" "smile" "\\_/")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
201 ("/~\\" "frown" "/~~\\")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
202 ("-<" "prec" ("-<" "く"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
203 ("-<=" "preceq" ("-<\n-" "く\n="))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
204 ("<<" "ll" ("<<" "《"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
205 ; :
390df0e505da Label completion works.
yuuji
parents:
diff changeset
206 ;;arrows
390df0e505da Label completion works.
yuuji
parents:
diff changeset
207 ("<-" "leftarrow" ("<-" "←"))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
208 ("\C-b" "leftarrow" ("<-" "←"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
209 ("<--" "longleftarrow" ("<--" "←--"))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
210 ("<=" "Leftarrow" "<=")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
211 ("<==" "Longleftarrow" "<==")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
212 ("->" "rightarrow" ("->" "→"))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
213 ("\C-f" "rightarrow" ("->" "→"))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
214 ("-->" "longrightarrow" ("-->" "--→"))
64
36a48185b95a Changes are listed in yatex.new.
yuuji
parents: 60
diff changeset
215 ("=>" "Rightarrow" "=>")
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
216 ("==>" "Longrightarrow" "==>")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
217 ("<->" "leftrightarrow" ("<->" "←→"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
218 ("<-->" "longleftrightarrow" ("<---->" "←--→"))
47
d7e7b4654058 Support special popup frame.
yuuji
parents: 37
diff changeset
219 ("<=>" "Leftrightarrow" "<=>")
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
220 ("<==>" "Longleftrightarrow" "<==>")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
221 ("^|" "uparrow" ("^\n|" "↑"))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
222 ("\C-p" "uparrow" ("^\n|" "↑"))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
223 ("^||" "Uparrow" "/\\\n||")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
224 ("\C-n" "downarrow" ("|\nv" "↓"))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
225 ("v|" "downarrow" ("|\nv" "↓"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
226 ("v||" "Downarrow" "||\n\\/")
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
227 ("|->" "mapsto" ("|->" "|→"))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
228 ("<-)" "hookleftarrow" (" ,\n<--+" " ヽ\n<--/"))
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
229 ("(->" "hookrightarrow" ("`\n+-->" "/\n\-->"))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
230 ("/-" "leftharpoonup" "/\n~~~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
231 ("\\-" "leftharpoondown" "__\n\\")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
232 ("-/" "rightharpoondown" "__\n/")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
233 ("-\\" "rightharpoonup" "~~\n\\")
53
5f4b18da14b3 Fix functions relating YaTeX-beginning-of-environment or
yuuji
parents: 52
diff changeset
234 ;;left and right
5f4b18da14b3 Fix functions relating YaTeX-beginning-of-environment or
yuuji
parents: 52
diff changeset
235 ("left" "left" "(leftmark)")
5f4b18da14b3 Fix functions relating YaTeX-beginning-of-environment or
yuuji
parents: 52
diff changeset
236 ("right" "right" "(rightmark)")
68
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
237 ;;accent marks
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
238 ("tilde" "tilde" "~\n?")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
239 ("T" "tilde" "~\n?")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
240 ("wtilde" "widetilde" "~\n?")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
241 ("hat" "hat" "^\n?")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
242 ("what" "widehat" "/\\\n??")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
243 ("w^" "widehat" "/\\\n?")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
244 ("check" "check" "v\n?")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
245 ("bar" "bar" "_\n?")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
246 ("overline" "overline" "_\n?")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
247 ("wbar" "overline" "--\n??")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
248 ("dot" "dot" ".\n?")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
249 ("ddot" "ddot" "..\n??")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
250 ("vec" "vec" ("->\n??" "→\n??"))
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
251 ("~>" "overrightarrow" ("-->\nAB" "→\nAB"))
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
252 ("VEC" "overrightarrow" ("-->\nAB" "→\nAB"))
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
253 ;;rage-aware stuffs
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
254 ("prod" "prod" ("-+--+-\n | |" "Π"))
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
255 ("CUP" "bigcup" "|~~|\n| |\n| |")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
256 ("union" "bigcup" "|~~|\n| |\n| |")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
257 ("CAP" "bigcap" "| |\n| |\n|__|")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
258 ("isc" "bigcap" "| |\n| |\n|__|")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
259 ("O+" "bigoplus" "/~~~\\\n| + |\n\\___/")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
260 ("Ox" "bigotimes" "/~~~\\\n| X |\n\\___/")
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
261 ;;other marks
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
262 ("Z" "aleph" "|\\|")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
263 ("|\\|" "aleph" "|\\|")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
264 ("h-" "hbar" "_\nh")
68
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
265 ; ("i" "imath" "i") ;These chars are appeared only
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
266 ; ("j" "jmath" "j") ;as section-type arguments
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
267 ("l" "ell" "l")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
268 ("wp" "wp" "???")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
269 ("R" "Re" ")R")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
270 ("Im" "Im" "???")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
271 ("mho" "mho" "~|_|~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
272 ("'" "prime" "'")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
273 ("0" "emptyset" "0")
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
274 ("nabla" "nabla" ("___\n\\\\/" YaTeX-image-nabla))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
275 ("\\/" "surd" "-\\/")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
276 ("surd" "surd" "-\\/")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
277 ("top" "top" "T")
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
278 ("bot" "bot" ("_|_" YaTeX-image-bot))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
279 ("b" "flat" ("b" YaTeX-image-flat))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
280 ("LT" "natural" "|\nLT\n |")
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
281 ("6" "partial" (" -+\n+-+\n+-+" YaTeX-image-partial))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
282 ("partial" "partial" (" -+\n+-+\n+-+" YaTeX-image-partial))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
283 ("round" "partial" (" -+\n+-+\n+-+" YaTeX-image-partial))
59
48ac97a6b6ce Call drawing tools
yuuji
parents: 58
diff changeset
284 ("[]" "Box" "[]")
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
285 ("Diamond" "Diamond" "/\\\n\\/")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
286 ("3" "triangle" "/\\\n~~")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
287 ("C" "clubsuit" " o\no+o\n |")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
288 ("D" "diamondsuit" "/\\\n\\/")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
289 ("H" "heartsuit" "<^^>\n \\/")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
290 ("S" "spadesuit" " /\\\n<++>\n /\\")
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
291 )
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
292 "Default LaTeX-math-command alist.")
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
293
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
294 (defvar YaTeX-math-sign-alist-private nil
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
295 "*User definable key vs LaTeX-math-command alist.")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
296
390df0e505da Label completion works.
yuuji
parents:
diff changeset
297 (defvar YaTeX-math-quit-with-strict-match nil
390df0e505da Label completion works.
yuuji
parents:
diff changeset
298 "*T for quitting completion as soon as strict-match is found.")
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
299 (defvar YaTeX-math-sign-alist
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
300 (append YaTeX-math-sign-alist-private YaTeX-math-sign-alist-default))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
301
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
302 ;;(defun YaTeX-math-alist2array (alist array)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
303 ;; (set array
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
304 ;; (let ((array (make-vector (length alist) "")) (list alist) (i 0))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
305 ;; (while list
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
306 ;; (aset array i (car (car list)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
307 ;; (setq i (1+ i) list (cdr list)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
308 ;; array))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
309 ;;)
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
310
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
311 (defvar YaTeX-greek-key-alist-default
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
312 '(
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
313 ("a" "alpha" ("a" "α"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
314 ("b" "beta" ("|>\n|>\n|" "β"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
315 ("g" "gamma" ("~r" "γ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
316 ("G" "Gamma" ("|~" "Γ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
317 ("d" "delta" ("<~\n<>" "δ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
318 ("D" "Delta" ("/\\\n~~" "Δ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
319 ("e" "epsilon" "<\n<~")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
320 ("e-" "varepsilon" ("(\n(~" "ε"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
321 ("z" "zeta" ("(~\n >" "ζ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
322 ("et" "eta" ("n\n/" "η"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
323 ("th" "theta" ("8" "θ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
324 ("Th" "Theta" ("(8)" "Θ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
325 ("th-" "vartheta" ("-8" "-θ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
326 ("i" "iota" ("i\n\\_/" "ι"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
327 ("k" "kappa" ("k" "κ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
328 ("l" "lambda" ("\\n/\\" "λ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
329 ("L" "Lambda" ("/\\" "Λ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
330 ("m" "mu" (" u_\n/" "μ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
331 ("n" "nu" ("|/" "ν"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
332 ("x" "xi" ("E\n >" "ξ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
333 ("X" "Xi" ("---\n -\n---" "Ξ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
334 ("p" "pi" ("__\n)(" "π"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
335 ("P" "Pi" ("__\n||" "Π"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
336 ("p-" "varpi" ("_\nw" "__\nω"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
337 ("r" "rho" ("/O" "ρ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
338 ("r-" "varrho" ("/O\n~~" "ρ\n~~"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
339 ("s" "sigma" ("o~" "σ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
340 ("S" "Sigma" ("\\-+\n >\n/-+" "Σ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
341 ("s-" "varsigma" "(~~ \n>")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
342 ("t" "tau" ("__\n(" "τ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
343 ("u" "upsilon" ("~v" "υ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
344 ("y" "upsilon" ("~v" "υ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
345 ("U" "Upsilon" ("~Y~" "Υ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
346 ("Y" "Upsilon" ("~Y~" "Υ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
347 ("ph" "phi" (" /\n(/)\n/" "φ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
348 ("Ph" "Phi" (" _\n(|)\n ~" "Φ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
349 ("ph-" "varphi" "\\O\n|")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
350 ("c" "chi" ("x" "χ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
351 ("ps" "psi" ("\\|/\\n |" "ψ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
352 ("Ps" "Psi" (" ~\n\\|/\\n |" "Ψ"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
353 ("o" "omega" ("w" "ω"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
354 ("w" "omega" ("w" "ω"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
355 ("O" "Omega" ("(~)\n~ ~" "Ω"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
356 ("W" "Omega" ("(~)\n~ ~" "Ω"))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
357 ("f" "foo")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
358 )
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
359 "Default LaTeX-math-command alist.")
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
360
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
361 (defvar YaTeX-greek-key-alist-private nil
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
362 "*User definable key vs LaTeX-math-command alist.")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
363
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
364 (defvar YaTeX-greek-key-alist
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
365 (append YaTeX-greek-key-alist-private YaTeX-greek-key-alist-default))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
366
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
367 ;;(mapcar (function (lambda (x) (YaTeX-math-alist2array x)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
368 ;; YaTeX-math-key-list)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
369
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
370 (defvar YaTeX-math-indicator "KEY\tLaTeX sequence\t\tsign")
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
371
390df0e505da Label completion works.
yuuji
parents:
diff changeset
372 (defvar YaTeX-math-need-image t
390df0e505da Label completion works.
yuuji
parents:
diff changeset
373 "*T for displaying pseudo image momentarily.")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
374 (defvar YaTeX-math-max-key 8)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
375 (defvar YaTeX-math-max-seq
390df0e505da Label completion works.
yuuji
parents:
diff changeset
376 (* 8 (1+ (/ (length "\\longleftrightarrow") 8))))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
377 (defvar YaTeX-math-max-sign 5)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
378 (defvar YaTeX-math-sign-width
390df0e505da Label completion works.
yuuji
parents:
diff changeset
379 (+ YaTeX-math-max-key YaTeX-math-max-seq YaTeX-math-max-sign))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
380 (defvar YaTeX-math-display-width
390df0e505da Label completion works.
yuuji
parents:
diff changeset
381 (* 8 (1+ (/ YaTeX-math-sign-width 8))))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
382 (defvar YaTeX-math-menu-map nil
390df0e505da Label completion works.
yuuji
parents:
diff changeset
383 "Keymap used in YaTeX mathematical sign menu mode."
390df0e505da Label completion works.
yuuji
parents:
diff changeset
384 )
390df0e505da Label completion works.
yuuji
parents:
diff changeset
385 (if YaTeX-math-menu-map nil
390df0e505da Label completion works.
yuuji
parents:
diff changeset
386 (setq YaTeX-math-menu-map (make-sparse-keymap))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
387 (define-key YaTeX-math-menu-map "n" 'next-line)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
388 (define-key YaTeX-math-menu-map "p" 'previous-line)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
389 (define-key YaTeX-math-menu-map "f" 'YaTeX-math-forward)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
390 (define-key YaTeX-math-menu-map "b" 'YaTeX-math-backward)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
391 (define-key YaTeX-math-menu-map "v" 'scroll-up)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
392 (define-key YaTeX-math-menu-map " " 'scroll-up)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
393 (define-key YaTeX-math-menu-map "c" 'scroll-up)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
394 (define-key YaTeX-math-menu-map "V" 'scroll-down)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
395 (define-key YaTeX-math-menu-map "r" 'scroll-down)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
396 (define-key YaTeX-math-menu-map "\^h" 'scroll-down)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
397 (define-key YaTeX-math-menu-map "<" 'beginning-of-buffer)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
398 (define-key YaTeX-math-menu-map ">" 'end-of-buffer)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
399 (define-key YaTeX-math-menu-map "\^m" 'exit-recursive-edit)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
400 (define-key YaTeX-math-menu-map "q" 'abort-recursive-edit))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
401
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
402 (defvar YaTeX-math-exit-key "\e"
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
403 "*Key sequence after prefix key of YaTeX-math-mode to exit from math-mode."
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
404 )
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
405
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
406 (defmacro YaTeX-math-japanese-sign (list)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
407 (list 'nth 1 list))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
408
72
0aaebd07dad0 Support font-lock on XEmacs-21, Emacs-20, Emacs-21.
yuuji
parents: 70
diff changeset
409 (defvar YaTeX-math-cmd-regexp (concat (regexp-quote YaTeX-ec) "[A-z|]"))
51
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
410 (defvar YaTeX-math-verbatim-environments
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
411 '("alltt")
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
412 "*List of environments in which LaTeX math mode is disabled.
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
413 This value is appended with YaTeX-verbatim-environments.")
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
414
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
415 ;;;
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
416 ;;YaTeX math-mode functions
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
417 ;;;
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
418 ;;;###autoload from yatex.el
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
419 (defun YaTeX-toggle-math-mode (&optional arg)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
420 (interactive "P")
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
421 (or (memq 'YaTeX-math-mode mode-line-format) nil
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
422 (setq mode-line-format
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
423 (append (list "" 'YaTeX-math-mode) mode-line-format)))
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
424 (if YaTeX-auto-math-mode nil ;Only effective on manual mode.
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
425 (if (or arg (null YaTeX-math-mode))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
426 (let (keys)
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
427 (setq YaTeX-math-mode "math:")
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
428 (message "Turn on math mode. Prefix keys are %s"
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
429 (mapconcat 'car YaTeX-math-key-list " "))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
430 (sit-for 3)
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
431 (message
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
432 (concat "To exit from math-mode, type `ESC' after prefix, "
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
433 "or type `"
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
434 (key-description
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
435 (car
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
436 (where-is-internal
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
437 'YaTeX-switch-mode-menu YaTeX-mode-map)))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
438 " $'")))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
439 (setq YaTeX-math-mode nil)
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
440 (message "Exit from math mode."))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
441 (set-buffer-modified-p (buffer-modified-p)))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
442 )
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
443
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
444 (defun YaTeX-math-forward (arg)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
445 (interactive "p")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
446 (re-search-forward YaTeX-math-cmd-regexp nil t arg))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
447
390df0e505da Label completion works.
yuuji
parents:
diff changeset
448 (defun YaTeX-math-backward (arg)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
449 (interactive "p")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
450 (re-search-backward YaTeX-math-cmd-regexp nil t arg))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
451
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
452 (defun YaTeX-math-gets (sign)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
453 (cond
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
454 ((null sign) nil)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
455 ((listp sign)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
456 (setq sign
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
457 (cond
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
458 (YaTeX-japan (YaTeX-math-japanese-sign sign))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
459 (t (car sign))))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
460 (YaTeX-math-gets sign))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
461 ((symbolp sign)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
462 (YaTeX-math-gets (symbol-value sign)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
463 (t sign))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
464 )
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
465
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
466 (defun YaTeX-math-get-sign (list)
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
467 (YaTeX-math-gets (car (cdr-safe (cdr-safe list))))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
468 )
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
469 (defvar YaTeX-math-section-type-regexp
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
470 "eqn\\\\\\sw+\\b"
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
471 "*Regexp of section-type math-mode macro")
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
472
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
473 (defun YaTeX-in-math-mode-p ()
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
474 "If current position is supposed to be in LaTeX-math-mode, return t."
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
475 (or (YaTeX-quick-in-environment-p
58
3a7c0c2bf16d Official support for AMS-LaTeX, HTML, xdvi -remote, Netscape
yuuji
parents: 57
diff changeset
476 (append
3a7c0c2bf16d Official support for AMS-LaTeX, HTML, xdvi -remote, Netscape
yuuji
parents: 57
diff changeset
477 '("math" "eqnarray" "equation" "eqnarray*" "displaymath");LaTeX
3a7c0c2bf16d Official support for AMS-LaTeX, HTML, xdvi -remote, Netscape
yuuji
parents: 57
diff changeset
478 (if YaTeX-use-AMS-LaTeX
3a7c0c2bf16d Official support for AMS-LaTeX, HTML, xdvi -remote, Netscape
yuuji
parents: 57
diff changeset
479 ;; And math modes of AMS-LaTeX
3a7c0c2bf16d Official support for AMS-LaTeX, HTML, xdvi -remote, Netscape
yuuji
parents: 57
diff changeset
480 '("align" "align*" "split" "multline" "multline*" "gather"
3a7c0c2bf16d Official support for AMS-LaTeX, HTML, xdvi -remote, Netscape
yuuji
parents: 57
diff changeset
481 "gather*" "aligned*" "gathered" "gathered*" "alignat"
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
482 "equation*" "cases"
58
3a7c0c2bf16d Official support for AMS-LaTeX, HTML, xdvi -remote, Netscape
yuuji
parents: 57
diff changeset
483 "alignat*" "xalignat" "xalignat*" "xxalignat" "xxalignat*"))))
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
484 (let*((p (point)) (nest 0) me0 r
57
18f4939986e6 (j)LaTeX2e supported
yuuji
parents: 56
diff changeset
485 (delim (concat YaTeX-sectioning-regexp "\\|^$\\|^\C-l"))
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
486 (boundary
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
487 (save-excursion
51
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
488 (if (looking-at delim)
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
489 (goto-char (max (point-min) (1- (point)))))
51
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
490 (re-search-backward delim nil 1)
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
491 (point))))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
492 (save-excursion
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
493 (cond
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
494 ((catch 'open
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
495 (save-excursion
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
496 (while (and (>= nest 0)
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
497 (re-search-backward
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
498 (concat YaTeX-ec-regexp ;\
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
499 "\\([()]\\|[][]\\)") boundary t))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
500 (setq me0 (match-end 0))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
501 (if (or (YaTeX-on-comment-p)
51
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
502 (YaTeX-literal-p)) nil
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
503 (if (or (= (char-after (1- me0)) ?\))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
504 (= (char-after (1- me0)) ?\]))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
505 (setq nest (1+ nest))
37
433b27a11019 Do not count \\[5pt] as the beginning of \[ (YaTeX-in-math-mode-p).
yuuji
parents: 23
diff changeset
506 (if (= (preceding-char) ?\\ ) nil;;\\[5pt]
433b27a11019 Do not count \\[5pt] as the beginning of \[ (YaTeX-in-math-mode-p).
yuuji
parents: 23
diff changeset
507 (setq nest (1- nest))))))
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
508 (if (< nest 0) (throw 'open t))))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
509 t)
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
510 ((and (setq r (YaTeX-on-section-command-p
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
511 YaTeX-math-section-type-regexp))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
512 (numberp r)
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
513 (> r 0))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
514 t)
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
515 (t (catch 'dollar
51
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
516 (while ;(search-backward "$" boundary t);little bit fast.
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
517 (YaTeX-re-search-active-backward ;;;;;; Too slow???
58
3a7c0c2bf16d Official support for AMS-LaTeX, HTML, xdvi -remote, Netscape
yuuji
parents: 57
diff changeset
518 "\\$" (concat "[^\\\\]" YaTeX-comment-prefix) boundary t)
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
519 (cond
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
520 ((equal (char-after (1- (point))) ?$) ; $$ equation $$
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
521 (backward-char 1)
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
522 (setq nest (1+ nest)))
51
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
523 ((let ((YaTeX-verbatim-environments
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
524 (append YaTeX-math-verbatim-environments
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
525 YaTeX-verbatim-environments)))
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
526 (YaTeX-literal-p))
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
527 nil)
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
528 ((and (equal (char-after (1- (point))) ?\\ )
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
529 (not (equal (char-after (- (point) 3)) ?\\ )))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
530 nil) ;\$
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
531 (t (setq nest (1+ nest)))))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
532 (if (= (% nest 2) 1) (throw 'dollar t))))))))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
533 )
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
534
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
535 (defun YaTeX-math-display-list (list cols)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
536 (goto-char (point-max))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
537 (if (= cols 0) (if (not (eolp)) (newline 1))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
538 (forward-line -1)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
539 (while (looking-at "[ \t\n]") (forward-line -1)))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
540 (end-of-line)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
541 (let ((indent (* YaTeX-math-display-width cols)) sign str to)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
542 (indent-to indent)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
543 (insert (car list))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
544 (indent-to (setq indent (+ indent YaTeX-math-max-key)))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
545 (insert "\\" (car (cdr list)))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
546 (setq indent (+ indent YaTeX-math-max-seq))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
547 (setq sign (YaTeX-math-get-sign list))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
548 (while (and sign (not (string= "" sign)))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
549 (setq to (string-match "\n" sign)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
550 str (if to (substring sign 0 to) sign))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
551 (end-of-line)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
552 (indent-to indent)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
553 (insert str)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
554 (cond ((eobp) (newline 1))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
555 ((> cols 0) (forward-line 1)))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
556 (setq sign (if to (substring sign (1+ to)) "")))))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
557
390df0e505da Label completion works.
yuuji
parents:
diff changeset
558 (defvar YaTeX-math-menu-buffer "*math-mode-signs*")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
559
390df0e505da Label completion works.
yuuji
parents:
diff changeset
560 (defun YaTeX-math-show-menu (match-str)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
561 (save-window-excursion
59
48ac97a6b6ce Call drawing tools
yuuji
parents: 58
diff changeset
562 (YaTeX-showup-buffer YaTeX-math-menu-buffer nil t)
70
44e3a5e1e883 Fix makefile for Windows
yuuji
parents: 69
diff changeset
563 (let ((maxcols (max 1 (/ (YaTeX-screen-width) YaTeX-math-sign-width)))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
564 (case-fold-search nil)
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
565 (cols 0) (list alist) command)
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
566 (erase-buffer)
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
567 (insert
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
568 "Candidates of sign. [n:next p:prev f:forw b:back q:quit RET:select]\n")
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
569 (insert YaTeX-math-indicator "\t")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
570 (insert YaTeX-math-indicator)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
571 (newline 1)
70
44e3a5e1e883 Fix makefile for Windows
yuuji
parents: 69
diff changeset
572 (insert-char ?- (1- (YaTeX-screen-width)))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
573 (newline 1)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
574 (while list
390df0e505da Label completion works.
yuuji
parents:
diff changeset
575 (if (string-match match-str (car (car list)))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
576 (progn (YaTeX-math-display-list (car list) cols)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
577 (setq cols (% (1+ cols) maxcols))))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
578 (setq list (cdr list)))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
579 (goto-line 4)
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
580 (use-local-map YaTeX-math-menu-map)
60
9e08ed569d80 yahtml: change keystroke of calling browser to [prefix] t p
yuuji
parents: 59
diff changeset
581 (setq buffer-read-only t)
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
582 (unwind-protect
390df0e505da Label completion works.
yuuji
parents:
diff changeset
583 (recursive-edit)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
584 (skip-chars-backward "^ \t\n")
390df0e505da Label completion works.
yuuji
parents:
diff changeset
585 (setq command
390df0e505da Label completion works.
yuuji
parents:
diff changeset
586 (if (re-search-forward YaTeX-math-cmd-regexp nil t)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
587 (buffer-substring
390df0e505da Label completion works.
yuuji
parents:
diff changeset
588 (match-beginning 0)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
589 (prog2 (skip-chars-forward "^ \t\n") (point)))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
590 nil))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
591 (kill-buffer YaTeX-math-menu-buffer))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
592 command))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
593 )
390df0e505da Label completion works.
yuuji
parents:
diff changeset
594
390df0e505da Label completion works.
yuuji
parents:
diff changeset
595 ;
390df0e505da Label completion works.
yuuji
parents:
diff changeset
596 (defun YaTeX-math-show-image (image &optional exit-char)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
597 "Momentarily display IMAGE at the beginning of the next line;
390df0e505da Label completion works.
yuuji
parents:
diff changeset
598 erase it on the next keystroke. The window is recentered if necessary
390df0e505da Label completion works.
yuuji
parents:
diff changeset
599 to make the whole string visible. If the window isn't large enough,
390df0e505da Label completion works.
yuuji
parents:
diff changeset
600 at least you get to read the beginning."
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
601 (if (and image (not (string= image "")))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
602 (let ((buffer-read-only nil)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
603 (modified (buffer-modified-p))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
604 (name buffer-file-name)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
605 insert-start
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
606 insert-end)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
607 (unwind-protect
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
608 (progn
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
609 (save-excursion
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
610 ;; defeat file locking... don't try this at home, kids!
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
611 (setq buffer-file-name nil)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
612 (forward-line 1)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
613 (setq insert-start (point))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
614 (if (eobp) (newline))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
615 (insert image)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
616 (setq insert-end (point)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
617 ; make sure the whole string is visible
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
618 (if (not (pos-visible-in-window-p insert-end))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
619 (recenter (max 0
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
620 (- (window-height)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
621 (count-lines insert-start insert-end)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
622 2))))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
623 (let ((char (read-char)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
624 (or (eq char exit-char)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
625 (setq unread-command-char char))))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
626 (if insert-end
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
627 (save-excursion
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
628 (delete-region insert-start insert-end)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
629 (setq buffer-file-name name)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
630 (set-buffer-modified-p modified)))))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
631
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
632 (defun YaTeX-math-insert-sequence (&optional force initial)
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
633 "Insert math-mode sequence with image completion."
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
634 (interactive "P")
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
635 (let*((key (or initial "")) regkey str last-char list i
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
636 (case-fold-search nil) match sign
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
637 (this-key (char-to-string last-command-char))
60
9e08ed569d80 yahtml: change keystroke of calling browser to [prefix] t p
yuuji
parents: 59
diff changeset
638 (alistsym (cdr (assoc this-key YaTeX-math-key-list)))
9e08ed569d80 yahtml: change keystroke of calling browser to [prefix] t p
yuuji
parents: 59
diff changeset
639 (alistname (symbol-name alistsym))
9e08ed569d80 yahtml: change keystroke of calling browser to [prefix] t p
yuuji
parents: 59
diff changeset
640 (alist (symbol-value alistsym))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
641 (n (length alist)) (beg (point)) result)
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
642 (if initial (insert YaTeX-ec (car (cdr (assoc initial alist)))))
60
9e08ed569d80 yahtml: change keystroke of calling browser to [prefix] t p
yuuji
parents: 59
diff changeset
643 (if (string-match "^YaTeX-" alistname)
9e08ed569d80 yahtml: change keystroke of calling browser to [prefix] t p
yuuji
parents: 59
diff changeset
644 (setq alistname (substring alistname (length "YaTeX-"))))
9e08ed569d80 yahtml: change keystroke of calling browser to [prefix] t p
yuuji
parents: 59
diff changeset
645 (setq alistname (substring alistname 0 (string-match "-" alistname)))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
646 (setq result
390df0e505da Label completion works.
yuuji
parents:
diff changeset
647 (catch 'complete
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
648 (if (and (not force)
51
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
649 (if YaTeX-auto-math-mode
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
650 (not (YaTeX-in-math-mode-p))
b0371b6ed799 Created `ChangeLog'.
yuuji
parents: 47
diff changeset
651 (not YaTeX-math-mode)))
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
652 (throw 'complete 'escape));this tag should be exit, but...
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
653 (while t
60
9e08ed569d80 yahtml: change keystroke of calling browser to [prefix] t p
yuuji
parents: 59
diff changeset
654 (message "%ssequence%s: %s"
9e08ed569d80 yahtml: change keystroke of calling browser to [prefix] t p
yuuji
parents: 59
diff changeset
655 (if YaTeX-simple-messages "" (concat alistname " "))
56
a9653fbd1c1c Bug fix version
yuuji
parents: 53
diff changeset
656 (if YaTeX-simple-messages "" "(TAB for menu)") key)
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
657 (setq last-char (read-char)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
658 key (concat key (char-to-string last-char))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
659 i 0)
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
660 (cond
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
661 ((string= key this-key) ;;invoke key itself
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
662 (throw 'complete 'escape))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
663 ((string= key YaTeX-math-exit-key) ;;exit from math-mode
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
664 (throw 'complete 'exit))
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
665 ((string-match "\r" key) ;;RET = kakutei
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
666 (throw 'complete 'select))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
667 ((string-match "[\C-g\C-c]" key) ;;C-g = abort
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
668 (throw 'complete 'abort))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
669 ((string-match "[\t\n]" key) ;;TAB, LFD = menu
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
670 (throw 'complete 'menu))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
671 ((string-match "[\C-h\C-?]" key) ;;BS, DEL = BS
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
672 (if (< (length key) 2) (throw 'complete 'abort))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
673 (setq key (substring key 0 -2))))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
674
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
675 (setq regkey (concat "^" (regexp-quote key)))
56
a9653fbd1c1c Bug fix version
yuuji
parents: 53
diff changeset
676 (message "Sequence%s: %s"
a9653fbd1c1c Bug fix version
yuuji
parents: 53
diff changeset
677 (if YaTeX-simple-messages "" "(TAB for menu)") key)
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
678 (if
390df0e505da Label completion works.
yuuji
parents:
diff changeset
679 (catch 'found
390df0e505da Label completion works.
yuuji
parents:
diff changeset
680 ;;(1)input string strictly matches with alist
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
681 (setq match (assoc key alist))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
682 ;;remember previous match
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
683
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
684 ;;(2)search partial match into alist
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
685 (setq list alist)
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
686 (while (< i n)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
687 (if (string-match
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
688 regkey
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
689 ;;(aref array i)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
690 ;;(car (nth i alist))
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
691 (car (car list)))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
692 (progn
390df0e505da Label completion works.
yuuji
parents:
diff changeset
693 (or match
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
694 ;;(setq match (nth i alist))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
695 (setq match (car list)))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
696 (throw 'found t)))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
697 (setq i (1+ i) list (cdr list)))) ;catch 'found
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
698 nil ;;if any match, continue reading
390df0e505da Label completion works.
yuuji
parents:
diff changeset
699 ;;else reading of sequence has been done.
390df0e505da Label completion works.
yuuji
parents:
diff changeset
700 (message "complete.")
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
701 (throw 'complete t))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
702
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
703 (if match
390df0e505da Label completion works.
yuuji
parents:
diff changeset
704 (progn (delete-region beg (point))
23
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
705 (setq single-command (car (cdr match)))
b00c74813e56 Change the YaTeX-math-mode's prefix from `,' to `;'.
yuuji
parents: 14
diff changeset
706 (insert YaTeX-ec single-command)
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
707 (if (and YaTeX-math-need-image
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
708 (setq sign (YaTeX-math-get-sign match)))
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
709 (YaTeX-math-show-image (concat sign "\n")))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
710 )
390df0e505da Label completion works.
yuuji
parents:
diff changeset
711 nil)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
712 )))
68
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
713 (delete-region beg (point))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
714 (cond
68
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
715 ((memq result '(t select))
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
716 (if (eq result t)
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
717 (setq unread-command-char last-char)
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
718 (message "Done."))
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
719 (if (assoc single-command section-table)
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
720 (YaTeX-make-section nil nil nil single-command)
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
721 (setq YaTeX-current-completion-type 'maketitle)
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
722 (YaTeX-make-singlecmd single-command)))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
723 ((eq result 'abort)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
724 (message "Abort."))
390df0e505da Label completion works.
yuuji
parents:
diff changeset
725 ((eq result 'escape)
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
726 (call-interactively (global-key-binding this-key)))
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
727 ((eq result 'exit)
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
728 (YaTeX-toggle-math-mode))
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
729 ((eq result 'menu)
390df0e505da Label completion works.
yuuji
parents:
diff changeset
730 (setq key (concat "^" (regexp-quote (substring key 0 -1))))
68
0eb6997bee16 More adjustment for Emacs20 and XEmacs
yuuji
parents: 64
diff changeset
731 (insert (YaTeX-math-show-menu key))))))
52
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
732
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
733 ;; ----- Change image completion types -----
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
734 (defun YaTeX-math-member-p (item)
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
735 "Check if ITEM is a member of image completion.
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
736 If so return the cons of its invocation key and image-string."
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
737 (let ((lists YaTeX-math-key-list) list)
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
738 (catch 'found
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
739 (while lists
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
740 (setq list (symbol-value (cdr (car lists))))
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
741 (while list
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
742 (if (string= item (nth 1 (car list)))
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
743 (throw 'found (cons (car (car lists)) (nth 0 (car list)))))
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
744 (setq list (cdr list)))
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
745 (setq lists (cdr lists))))))
5d94deabb9f9 Set YaTeX-indent-line to 'indent-line-function.
yuuji
parents: 51
diff changeset
746
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
747 ;;; ----- for AMS LaTeX (by matsu@math.s.chiba-u.ac.jp) -----
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
748 (defvar YaTeX-ams-paren-modifier
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
749 '(("Biggl" . "Biggr") ("biggl" . "biggr")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
750 ("Bigl" . "Bigr") ("bigl" . "bigr")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
751 ("left" . "right") ("" . ""))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
752 "Alist of modifier of parentheses.")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
753
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
754 (defvar YaTeX-left-paren "(\\|\\[\\|\\\\{")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
755 (defvar YaTeX-right-paren ")\\|\\]\\|\\\\}")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
756 (defvar YaTeX-paren
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
757 (concat YaTeX-left-paren "\\|" YaTeX-right-paren))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
758
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
759 (defun YaTeX-on-parenthesis-p ()
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
760 "If cursor is on an (AMS-LaTeX) parenthesis, return the parenthesis."
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
761 (interactive)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
762 (let* ((list YaTeX-ams-paren-modifier)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
763 (longest 0) ;; the longest length of parenthesis command strings
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
764 (flag t) ;; flag for whether on braces not following \
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
765 (point (point))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
766 (move 0)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
767 (paren))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
768 (while list
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
769 (setq longest
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
770 (max longest (length (car (car list))) (length (cdr (car list)))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
771 (setq list (cdr list)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
772 (save-excursion
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
773 ;; search {} and, if it does not follow `\', set flag nil.
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
774 ;; if it is right after `\', set flag t and move to the position of \.
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
775 ;; mmmmm.
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
776 (if (looking-at "{\\|}")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
777 (if (not (equal (char-after (1- (point))) 92))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
778 (setq flag nil)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
779 (forward-char -1)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
780 ;; if flag is nil, do nothing.
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
781 (if (and flag (re-search-forward YaTeX-paren
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
782 (+ (point) 3 longest) t))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
783 (progn
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
784 (setq move (- (point) point))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
785 (setq paren (match-string 0))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
786 (setq list YaTeX-ams-paren-modifier)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
787 ;; criterion for whether on [] () \{\} or not.
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
788 (if (string-match YaTeX-left-paren paren)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
789 (while (and list flag)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
790 (let* ((mod (car (car list)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
791 (mod-length 0) ;; length of modifier
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
792 paren-regexp ;; regexp of paren.
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
793 mod-regexp) ;; regexp of modifier.
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
794 (if (> (length mod) 0)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
795 (setq mod-regexp (concat "\\\\" mod)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
796 mod-length (1+ (length mod))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
797 (cond ((string= paren "\\{")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
798 (setq paren-regexp (concat "\\" paren)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
799 ((string= paren "[")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
800 (setq paren-regexp "\\["))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
801 (t (setq paren-regexp paren)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
802 (save-excursion
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
803 (if (and (>= (- (point) (point-min))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
804 (+ mod-length (length paren)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
805 (not (forward-char
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
806 (- 0 mod-length (length paren))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
807 (looking-at (concat "\\(" mod-regexp "\\)\\("
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
808 paren-regexp "\\)")))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
809 (setq flag nil)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
810 (setq list (cdr list))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
811 (while (and list flag)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
812 (let* ((mod (cdr (car list)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
813 (mod-length 0)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
814 paren-regexp
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
815 mod-regexp)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
816 (if (> (length mod) 0)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
817 (setq mod-regexp (concat "\\\\" mod)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
818 mod-length (1+ (length mod))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
819 (cond ((string= paren "\\}")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
820 (setq paren-regexp (concat "\\" paren)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
821 ((string= paren "]")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
822 (setq paren-regexp "\\]"))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
823 (t (setq paren-regexp paren)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
824 (save-excursion
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
825 (if (and (>= (- (point) (point-min))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
826 (+ mod-length (length paren)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
827 (not (forward-char
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
828 (- 0 mod-length (length paren))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
829 (looking-at (concat "\\(" mod-regexp "\\)\\("
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
830 paren-regexp "\\)")))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
831 (setq flag nil)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
832 (setq list (cdr list)))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
833 (if (<= move (length (match-string 0)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
834 (match-string 0)))))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
835
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
836 (defun YaTeX-goto-open-paren (&optional jumpto-co)
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
837 "Jump to the exact position of open parenthesis.
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
838 If optional argument JUMPTO-CO is non-nil, goto corresponding parentheses."
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
839 (interactive)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
840 (let ((paren)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
841 (backslash-syntax (char-to-string (char-syntax ?\\))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
842 (if (setq paren (YaTeX-on-parenthesis-p))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
843 (if (string-match "(\\|{\\|\\[" paren (1- (length paren)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
844 (progn
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
845 (re-search-forward "(\\|{\\|\\[" (+ (point) (length paren)) t)
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
846 (backward-char)
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
847 (if jumpto-co
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
848 (unwind-protect
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
849 (progn
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
850 (modify-syntax-entry ?\\ " ")
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
851 (forward-list)
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
852 (backward-char))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
853 (modify-syntax-entry ?\\ backslash-syntax)))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
854 (point))
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
855 (re-search-forward ")\\|}\\|\\]" (+ (point) (length paren)) t)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
856 (unwind-protect
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
857 (progn
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
858 (modify-syntax-entry ?\\ " ")
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
859 (backward-list)
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
860 (point))
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
861 (modify-syntax-entry ?\\ backslash-syntax))))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
862
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
863 ;;;###autoload
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
864 (defun YaTeX-goto-corresponding-paren ()
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
865 "Go to corresponding mathematical parentheses."
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
866 (if (YaTeX-on-parenthesis-p)
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
867 (YaTeX-goto-open-paren t)
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
868 nil))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
869
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
870 (defun YaTeX-change-parentheses ()
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
871 "Change the size of parentheses, braces, and brackets of AMS-LaTeX."
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
872 (interactive)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
873 (if (not (and YaTeX-use-AMS-LaTeX (YaTeX-on-parenthesis-p)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
874 nil
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
875 (let* ((mod (match-string 1)) ;; modifier
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
876 (paren (if mod (match-string 2) (match-string 0))) ;; paren
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
877 (mod-length (if (or (string= mod "\\left") (string= mod "\\right"))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
878 5 ;; 5 in case left or right
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
879 (length mod))) ;; length of modifier
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
880 (paren-length (length paren)) ;; length of paren
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
881 (length (+ mod-length paren-length)) ;; length of whole string
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
882 (big-p t) ;; flag whether new modifier is "[Bb]ig+" or not.
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
883 size ;; left, big, Big etc.
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
884 type ;; parentheses type
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
885 lr ;; "l" or "r".
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
886 char newsize newsize-length
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
887 (backslash-syntax (char-to-string (char-syntax ?\\)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
888 (case-fold-search))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
889 ;; decide lr and size from mod and paren.
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
890 (cond ((string-match "\\(\\\\[Bb]ig+\\)[lr]" mod)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
891 (setq size (substring mod 1 (match-end 1))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
892 lr (substring mod (match-end 1) (match-end 0))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
893 ((string-match "\\\\left" mod)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
894 (setq size "left-right" lr "l"))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
895 ((string-match "\\\\right" mod)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
896 (setq size "left-right" lr "r"))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
897 ((string-match "(\\|\\[\\|\\\\{" paren)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
898 (setq size "null" lr "l"))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
899 ((string-match ")\\|\\]\\|\\\\}" paren)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
900 (setq size "null" lr "r"))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
901 (t
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
902 (setq size nil lr nil)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
903 (while (not newsize)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
904 (message (format (concat "Change from %s: "
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
905 "l(big) L(Big) h(bigg) H(Bigg) "
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
906 "r(left-right) n(NONE) ( { [") size))
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
907 (setq char (read-char)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
908 newsize (cond ((char-equal char ?l) "\\big")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
909 ((char-equal char ?L) "\\Big")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
910 ((char-equal char ?h) "\\bigg")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
911 ((char-equal char ?H) "\\Bigg")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
912 ((char-equal char ?r)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
913 (setq big-p nil) "\\left")
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
914 ((memq char '(?\( ?\)))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
915 (setq big-p nil type '("(" . ")")) "")
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
916 ((memq char '(?\{ ?\}))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
917 (setq big-p nil type '("\\{" . "\\}")) "")
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
918 ((memq char '(?\[ ?\]))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
919 (setq big-p nil type '("[" . "]")) "")
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
920 ((char-equal char ?n)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
921 (setq big-p nil) "")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
922 (t nil))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
923 newsize-length (length newsize)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
924 (YaTeX-goto-open-paren)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
925 (forward-char)
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
926 (cond
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
927 (type
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
928 (delete-region (point) (- (point) paren-length))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
929 (save-excursion (insert (car type))))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
930 (t
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
931 (delete-region (- (point) length) (- (point) paren-length))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
932 (backward-char paren-length)))
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
933 (insert-string newsize)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
934 (if big-p (insert ?l))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
935 (unwind-protect
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
936 (progn
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
937 (modify-syntax-entry ?\\ " ")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
938 (forward-list)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
939 (if (string= size "left-right") (setq length (1+ length)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
940 (if (eq char ?r) (setq newsize "\\right"))
77
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
941 (cond
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
942 (type
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
943 (delete-region (point) (- (point) paren-length))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
944 (insert (cdr type)))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
945 (t
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
946 (delete-region (- (point) length) (- (point) paren-length))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
947 (backward-char paren-length)
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
948 (insert-string newsize)
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
949 (if big-p (insert ?r))
1b172d26b55e Fix auto-fill movement on Emacs21.
yuuji
parents: 72
diff changeset
950 (forward-char paren-length)))
69
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
951 (if (string= lr "l") (backward-list)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
952 (modify-syntax-entry ?\\ backslash-syntax))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
953 t)))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
954
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
955 (defun YaTeX-insert-amsparens-region (beg end char)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
956 (interactive "r\ncWhich one ? l(big) L(Big) h(bigg) H(Bigg): ")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
957 (let* ((case-fold-search)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
958 (st (cond ((char-equal char ?l) "big")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
959 ((char-equal char ?L) "Big")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
960 ((char-equal char ?h) "bigg")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
961 ((char-equal char ?H) "Bigg"))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
962 (if st
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
963 (YaTeX-insert-braces-region
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
964 beg end (concat "\\" st "l(") (concat "\\" st "r)"))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
965 (YaTeX-insert-braces-region beg end "(" ")"))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
966
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
967 (defun YaTeX-insert-amsbraces-region (beg end char)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
968 (interactive "r\ncWhich one ? l(big) L(Big) h(bigg) H(Bigg): ")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
969 (let* ((case-fold-search)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
970 (st (cond ((char-equal char ?l) "big")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
971 ((char-equal char ?L) "Big")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
972 ((char-equal char ?h) "bigg")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
973 ((char-equal char ?H) "Bigg"))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
974 (if st
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
975 (YaTeX-insert-braces-region
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
976 beg end (concat "\\" st "l\\{") (concat "\\" st "r\\}"))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
977 (YaTeX-insert-braces-region beg end "\\{" "\\}"))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
978
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
979 (defun YaTeX-insert-amsbrackets-region (beg end char)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
980 (interactive "r\ncWhich one ? l(big) L(Big) h(bigg) H(Bigg): ")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
981 (let* ((case-fold-search)
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
982 (st (cond ((char-equal char ?l) "big")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
983 ((char-equal char ?L) "Big")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
984 ((char-equal char ?h) "bigg")
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
985 ((char-equal char ?H) "Bigg"))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
986 (if st
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
987 (YaTeX-insert-braces-region
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
988 beg end (concat "\\" st "l[") (concat "\\" st "r]"))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
989 (YaTeX-insert-braces-region beg end "[" "]"))))
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
990
807c1e7e68b7 yahtml-escape-chars-region
yuuji
parents: 68
diff changeset
991
11
390df0e505da Label completion works.
yuuji
parents:
diff changeset
992 ;;
390df0e505da Label completion works.
yuuji
parents:
diff changeset
993 (provide 'yatexmth)
13
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
994
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
995 ; Local variables:
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
996 ; fill-prefix: ";;; "
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
997 ; paragraph-start: "^$\\| \\|;;;$"
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
998 ; paragraph-separate: "^$\\| \\|;;;$"
eafae54794a0 Show message at comment-region on begin/end mode.
yuuji
parents: 11
diff changeset
999 ; End:

yatex.org