]> git.eshelyaron.com Git - emacs.git/commitdiff
New file.
authorKenichi Handa <handa@m17n.org>
Mon, 17 May 2004 00:21:11 +0000 (00:21 +0000)
committerKenichi Handa <handa@m17n.org>
Mon, 17 May 2004 00:21:11 +0000 (00:21 +0000)
leim/quail/sisheng.el [new file with mode: 0644]

diff --git a/leim/quail/sisheng.el b/leim/quail/sisheng.el
new file mode 100644 (file)
index 0000000..2451278
--- /dev/null
@@ -0,0 +1,290 @@
+;;; sisheng.el --- sisheng input method for Chinese pinyin transliteration
+
+;; Copyright (C) 2004  Free Software Foundation, Inc.
+
+;; Author: Werner LEMBERG <wl@gnu.org>
+
+;; Keywords: multilingual, input method, Chinese, pinyin, sisheng
+
+;; This program is free software; you can redistribute it and/or modify
+;; it under the terms of the GNU General Public License as published by
+;; the Free Software Foundation; either version 2, or (at your option)
+;; any later version.
+
+;; This program is distributed in the hope that it will be useful,
+;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+;; GNU General Public License for more details.
+
+;; You should have received a copy of the GNU General Public License
+;; along with GNU Emacs; see the file COPYING.  If not, write to
+;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
+
+;;; Commentary:
+
+;;; Code:
+
+(require 'quail)
+
+(defconst sisheng-regexp
+  "[āēīōūǖ]\\|üē")
+
+;; First element is the key,
+;; second element is the vowel used for the input sequence,
+;; last four elements are the resulting tones.
+;;
+(defconst sisheng-vowel-table
+  '(("ā" "a" "ā" "á" "ǎ" "à")
+    ("ē" "e" "ē" "é" "ě" "è")
+    ("ī" "i" "ī" "í" "ǐ" "ì")
+    ("ō" "o" "ō" "ó" "ǒ" "ò")
+    ("ū" "u" "ū" "ú" "ǔ" "ù")
+    ("ǖ" "v" "ǖ" "ǘ" "ǚ" "ǜ")
+    ("üē" "ve" "üē" "üé" "üě" "üè")))
+
+
+;; All possible syllables in Mandarin Chinese, presented in the first
+;; tone.  Note that make-sisheng-rules always constructs rules for all
+;; four tones even if some of those tones aren't used in Mandarin.
+;;
+(defconst sisheng-syllable-table
+  '("ā" "āi" "ān" "āng" "āo"
+
+    "bā" "bāi" "bān" "bāng" "bāo"
+    "bēi" "bēn" "bēng"
+    "bī" "biān" "biāo" "biē" "bīn" "bīng"
+    "bō"
+    "bū"
+
+    "cā" "cāi" "cān" "cāng" "cāo"
+    "cē" "cēn" "cēng"
+    "cī"
+    "cōng" "cōu"
+    "cū" "cuān" "cuī" "cūn" "cuō"
+
+    "chā" "chāi" "chān" "chāng" "chāo"
+    "chē" "chēn" "chēng"
+    "chī"
+    "chōng" "chōu"
+    "chū" "chuā" "chuāi" "chuān" "chuāng" "chuī" "chūn" "chuō"
+
+    "dā" "dāi" "dān" "dāng" "dāo"
+    "dē" "dēi" "dēn" "dēng"
+    "dī" "diān" "diāo" "diē" "dīng" "diū"
+    "dōng" "dōu"
+    "dū" "duān" "duī" "dūn" "duō"
+
+    "ē" "ēi" "ēn" "ēng" "ēr"
+
+    "fā" "fān" "fāng"
+    "fēi" "fēn" "fēng"
+    "fiāo"
+    "fō" "fōu"
+    "fū"
+
+    "gā" "gāi" "gān" "gāng" "gāo"
+    "gē" "gēi" "gēn" "gēng"
+    "gōng" "gōu"
+    "gū" "guā" "guāi" "guān" "guāng" "guī" "gūn" "guō"
+
+    "hā" "hāi" "hān" "hāng" "hāo"
+    "hē" "hēi" "hēn" "hēng"
+    "hōng" "hōu"
+    "hū" "huā" "huāi" "huān" "huāng" "huī" "hūn" "huō"
+
+    "jī" "jiā" "jiān" "jiāng" "jiāo" "jiē" "jīn" "jīng" "jiōng" "jiū"
+    "jū" "juān" "juē" "jūn"
+
+    "kā" "kāi" "kān" "kāng" "kāo"
+    "kē" "kēi" "kēn" "kēng"
+    "kōng" "kōu"
+    "kū" "kuā" "kuāi" "kuān" "kuāng" "kuī" "kūn" "kuō"
+
+    "lā" "lāi" "lān" "lāng" "lāo"
+    "lē" "lēi" "lēng"
+    "lī" "liā" "liān" "liāng" "liāo" "liē" "līn" "līng" "liū"
+    "lōng" "lōu"
+    "lū" "luān" "lūn" "luō"
+    "lǖ" "lüē"
+
+    "mā" "māi" "mān" "māng" "māo"
+    "mē" "mēi" "mēn" "mēng"
+    "mī" "miān" "miāo" "miē" "mīn" "mīng" "miū"
+    "mō" "mōu"
+    "mū"
+
+    "nā" "nāi" "nān" "nāng" "nāo"
+    "nē" "nēi" "nēn" "nēng"
+    "nī" "niān" "niāng" "niāo" "niē" "nīn" "nīng" "niū"
+    "nōng" "nōu"
+    "nū" "nuān" "nuō"
+    "nǖ" "nüē"
+
+    "ō" "ōu"
+
+    "pā" "pāi" "pān" "pāng" "pāo"
+    "pēi" "pēn" "pēng"
+    "pī" "piān" "piāo" "piē" "pīn" "pīng"
+    "pō" "pōu"
+    "pū"
+
+    "qī" "qiā" "qiān" "qiāng" "qiāo" "qiē" "qīn" "qīng" "qiōng" "qiū"
+    "qū" "quān" "quē" "qūn"
+
+    "rān" "rāng" "rāo"
+    "rē" "rēn" "rēng"
+    "rī"
+    "rōng" "rōu"
+    "rū" "ruā" "ruān" "ruī" "rūn" "ruō"
+
+    "sā" "sāi" "sān" "sāng" "sāo"
+    "sē" "sēn" "sēng"
+    "sī"
+    "sōng" "sōu"
+    "sū" "suān" "suī" "sūn" "suō"
+
+    "shā" "shāi" "shān" "shāng" "shāo"
+    "shē" "shēi" "shēn" "shēng"
+    "shī"
+    "shōu"
+    "shū" "shuā" "shuāi" "shuān" "shuāng" "shuī" "shūn" "shuō"
+
+    "tā" "tāi" "tān" "tāng" "tāo"
+    "tē" "tēi" "tēng"
+    "tī" "tiān" "tiāo" "tiē" "tīng"
+    "tōng" "tōu"
+    "tū" "tuān" "tuī" "tūn" "tuō"
+
+    "wā" "wāi" "wān" "wāng"
+    "wēi" "wēn" "wēng"
+    "wō"
+    "wū"
+
+    "xī" "xiā" "xiān" "xiāng" "xiāo" "xiē" "xīn" "xīng" "xiōng" "xiū"
+    "xū" "xuān" "xuē" "xūn"
+
+    "yā" "yān" "yāng" "yāo"
+    "yē"
+    "yī" "yīn" "yīng"
+    "yō" "yōng" "yōu"
+    "yū" "yuān" "yuē" "yūn"
+
+    "zā" "zāi" "zān" "zāng" "zāo"
+    "zē" "zēi" "zēn" "zēng"
+    "zī"
+    "zōng" "zōu"
+    "zū" "zuān" "zuī" "zūn" "zuō"
+
+    "zhā" "zhāi" "zhān" "zhāng" "zhāo"
+    "zhē" "zhēi" "zhēn" "zhēng"
+    "zhī"
+    "zhōng" "zhōu"
+    "zhū" "zhuā" "zhuāi" "zhuān" "zhuāng" "zhuī" "zhūn" "zhuō"))
+
+;; This function converts e.g.
+;;
+;;   "zhuō"
+;;
+;; into
+;;
+;;   (("zhuo4" ["zhuò"])
+;;    ("zhuo3" ["zhuǒ"])
+;;    ("zhuo2" ["zhuó"])
+;;    ("zhuo1" ["zhuō"]))
+;;
+(defun quail-make-sisheng-rules (syllable)
+  (let ((case-fold-search t)
+       vowel-match
+       vowel-list
+       input-vowel
+       base-key
+       key
+       value
+       key-value-list
+       (i 1))
+    (string-match sisheng-regexp syllable)
+    (setq vowel-match (downcase (match-string 0 syllable)))
+    (setq vowel-list
+         (cdr (assoc-string vowel-match sisheng-vowel-table)))
+    (setq input-vowel (car vowel-list))
+    (setq base-key (replace-match input-vowel nil nil syllable))
+    (while (<= i 4)
+      (setq key (concat base-key (number-to-string i)))
+      (setq value (vector (replace-match (nth i vowel-list) nil nil syllable)))
+      (push (list key value) key-value-list)
+      (setq i (1+ i)))
+    key-value-list))
+
+;; Set up sisheng input method.
+;;
+(quail-define-package
+ "chinese-sisheng"                     ; name
+ "Chinese"                             ; language
+ "ǚ"                                  ; title
+ t                                     ; guidance
+ "Sìshēng input method for pīnyīn transliteration of Chinese.
+
+Examples: shuang1 -> shuāng
+          Lv3     -> Lǚ
+          AN4     -> ÀN
+
+Use the fifth (unstressed) tone for syllables containing `ü'
+without a tone mark.
+
+Example:  nve5    -> nüe
+"                                      ; docstring
+ nil                                   ; translation-keys
+ t                                     ; forget-last-selection
+ nil                                   ; deterministic
+ nil                                   ; kbd-translate
+ nil                                   ; show-layout
+ nil                                   ; create-decode-map
+ nil                                   ; maximum-shortest
+ nil                                   ; overlay-plist
+ nil                                   ; update-translation-function
+ nil                                   ; conversion-keys
+ t                                     ; simple
+ )
+
+;; Call quail-make-sisheng-rules for all syllables in sisheng-syllable-table.
+;;
+(let ((case-table-save (current-case-table))
+      sisheng-list)
+  (set-case-table (standard-case-table))
+  (dolist (syllable sisheng-syllable-table)
+    (setq sisheng-list
+         (append (quail-make-sisheng-rules syllable)
+                 sisheng-list)))
+
+  (dolist (syllable sisheng-syllable-table)
+    (setq sisheng-list
+         (append (quail-make-sisheng-rules (upcase-initials syllable))
+                 sisheng-list)))
+
+  (dolist (syllable sisheng-syllable-table)
+    (setq sisheng-list
+         (append (quail-make-sisheng-rules (upcase syllable))
+                 sisheng-list)))
+
+  (eval `(quail-define-rules
+         ,@sisheng-list
+       
+         ("lv5" ["lü"])
+         ("lve5" ["lüe"])
+         ("nv5" ["nü"])
+         ("nve5" ["nüe"])
+
+         ("Lv5" ["Lü"])
+         ("Lve5" ["Lüe"])
+         ("Nv5" ["Nü"])
+         ("Nve5" ["Nüe"])
+
+         ("LV5" ["LÜ"])
+         ("LVE5" ["LÜE"])
+         ("NV5" ["NÜ"])
+         ("NVE5" ["NÜE"])))
+  (set-case-table case-table-save))
+
+;; Local Variables:
+;; coding: utf-8
+;; End: