annotate yatexmth.el @ 84:73cba5ddd111 yuuji v0

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

yatex.org