Merge from mainline.
[bpt/emacs.git] / leim / quail / japanese.el
dissimilarity index 71%
index 8729073..e1f7e74 100644 (file)
-;;; quail/japanese.el --- Quail package for inputting Japanese
-
-;; Copyright (C) 1997 Electrotechnical Laboratory, JAPAN.
-;; Licensed to the Free Software Foundation.
-
-;; Keywords: multilingual, input method, Japanese
-
-;; This file is part of GNU Emacs.
-
-;; GNU Emacs 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.
-
-;; GNU Emacs 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, Inc., 59 Temple Place - Suite 330,
-;; Boston, MA 02111-1307, USA.
-
-;;; Code:
-
-(require 'quail)
-(require 'kkc)
-
-;; Update Quail translation region for Japanese bizarre translation
-;; rules.
-(defun quail-japanese-update-translation (control-flag)
-  (cond ((eq control-flag t)
-        (insert quail-current-str)
-        (quail-terminate-translation))
-       ((null control-flag)
-        (if (/= (aref quail-current-key 0) ?q)
-            (insert (or quail-current-str quail-current-key))))
-       (t                              ; i.e. (numberp control-flag)
-        (cond ((= (aref quail-current-key 0) ?n)
-               (insert ?\e$B$s\e(B))
-              ((= (aref quail-current-key 0) (aref quail-current-key 1))
-               (insert ?\e$B$C\e(B))
-              (t
-               (insert (aref quail-current-key 0))))
-        (setq unread-command-events
-              (list (aref quail-current-key control-flag)))
-        (quail-terminate-translation))))
-        
-;; Flag to control the behavior of `quail-japanese-toggle-kana'.
-(defvar quail-japanese-kana-state nil)
-(make-variable-buffer-local 'quail-japanese-kana-state)
-
-;; Convert Hiragana <-> Katakana in the current translation region.
-(defun quail-japanese-toggle-kana ()
-  (interactive)
-  (if (quail-point-in-conversion-region)
-      (let ((start (overlay-start quail-conv-overlay))
-           (end (overlay-end quail-conv-overlay)))
-       (setq quail-japanese-kana-state
-             (if (eq last-command this-command)
-                 (not quail-japanese-kana-state)))
-       (if quail-japanese-kana-state
-           (japanese-hiragana-region start end)
-         (japanese-katakana-region start end))
-       (goto-char (overlay-end quail-conv-overlay))
-       (setq quail-exit-conversion-mode t))
-    ;; When this command is invoked, the point is not in a valid
-    ;; region.  Try the event which invoked this command again out of
-    ;; conversion mode.
-    (setq unread-command-events (list last-command-event))
-    (throw 'exit nil)))
-
-;; Convert Hiragana in the current translation region to Kanji by KKC
-;; (Kana Kanji Converter) utility.
-(defun quail-japanese-kanji-kkc ()
-  (interactive)
-  (if (quail-point-in-conversion-region)
-      (let ((from (overlay-start quail-conv-overlay))
-           (to (overlay-end quail-conv-overlay))
-           newfrom)
-       (delete-overlay quail-overlay)
-       (delete-overlay quail-conv-overlay)
-       (unwind-protect
-           (setq newfrom (kkc-region from to))
-         ;; Activate the original (or shrinked) conversion region
-         ;; again.       
-         (if newfrom
-             ;; `kkc-region' is canceled.  
-             (move-overlay quail-conv-overlay newfrom (point))
-           ;; `kkc-region' is terminated normally.
-           (move-overlay quail-conv-overlay from (point))
-           (throw 'exit nil))))
-    ;; When this command is invoked, the point is not in a valid
-    ;; region.  Try the event which invoked this command again out of
-    ;; conversion mode.
-    (setq unread-command-events (list last-command-event))
-    (throw 'exit nil)))
-
-(defun quail-japanese-self-insert-and-switch-to-alpha (key idx)
-  (quail-delete-region)
-  (setq unread-command-events (list (aref key (1- idx))))
-  (quail-japanese-switch-package "q" 1))
-
-(defvar quail-japanese-switch-table
-  '((?z . "japanese-zenkaku")
-    (?k . "japanese-hankaku-kana")
-    (?h . "japanese")
-    (?q . ("japanese-ascii"))))
-
-(defvar quail-japanese-package-saved nil)
-(make-variable-buffer-local 'quail-japanese-package-saved)
-(put 'quail-japanese-package-saved 'permanent-local t)
-
-(defun quail-japanese-switch-package (key idx)
-  (let ((pkg (cdr (assq (aref key (1- idx)) quail-japanese-switch-table))))
-    (if (null pkg)
-       (error "No package to be switched")
-      (quail-delete-region)
-      (if (stringp pkg)
-         (select-input-method pkg)
-       (if (string= (car pkg) current-input-method)
-           (if quail-japanese-package-saved
-               (select-input-method quail-japanese-package-saved))
-         (setq quail-japanese-package-saved current-input-method)
-         (select-input-method (car pkg))))
-      (throw 'quail-tag nil))))
-
-(quail-define-package
- "japanese" "Japanese" "A\e$B$"\e(B"
- nil
- "Romaji -> Hiragana -> Kanji&Kana
----- Special key bindings ----
-qq:    toggle between input methods `japanese' and `japanese-ascii'
-qz:    use `japanese-zenkaku' package, \"qh\" puts you back to `japanese'
-K:     convert to Katakana
-SPC:   convert to Kanji&Kana
-z:     insert one Japanese symbol according to a key which follows
-"
- nil t t nil nil nil nil nil
- 'quail-japanese-update-translation
- '(("K" . quail-japanese-toggle-kana)
-   (" " . quail-japanese-kanji-kkc)
-   ("\C-m" . quail-no-conversion)
-   ([return] . quail-no-conversion))
- )
-
-(quail-define-rules
-
-( "a" "\e$B$"\e(B") ( "i" "\e$B$$\e(B") ( "u" "\e$B$&\e(B") ( "e" "\e$B$(\e(B") ( "o" "\e$B$*\e(B")
-("ka" "\e$B$+\e(B") ("ki" "\e$B$-\e(B") ("ku" "\e$B$/\e(B") ("ke" "\e$B$1\e(B") ("ko" "\e$B$3\e(B")
-("sa" "\e$B$5\e(B") ("si" "\e$B$7\e(B") ("su" "\e$B$9\e(B") ("se" "\e$B$;\e(B") ("so" "\e$B$=\e(B")
-("ta" "\e$B$?\e(B") ("ti" "\e$B$A\e(B") ("tu" "\e$B$D\e(B") ("te" "\e$B$F\e(B") ("to" "\e$B$H\e(B")
-("na" "\e$B$J\e(B") ("ni" "\e$B$K\e(B") ("nu" "\e$B$L\e(B") ("ne" "\e$B$M\e(B") ("no" "\e$B$N\e(B")
-("ha" "\e$B$O\e(B") ("hi" "\e$B$R\e(B") ("hu" "\e$B$U\e(B") ("he" "\e$B$X\e(B") ("ho" "\e$B$[\e(B")
-("ma" "\e$B$^\e(B") ("mi" "\e$B$_\e(B") ("mu" "\e$B$`\e(B") ("me" "\e$B$a\e(B") ("mo" "\e$B$b\e(B")
-("ya" "\e$B$d\e(B")             ("yu" "\e$B$f\e(B")             ("yo" "\e$B$h\e(B")
-("ra" "\e$B$i\e(B") ("ri" "\e$B$j\e(B") ("ru" "\e$B$k\e(B") ("re" "\e$B$l\e(B") ("ro" "\e$B$m\e(B")
-("la" "\e$B$i\e(B") ("li" "\e$B$j\e(B") ("lu" "\e$B$k\e(B") ("le" "\e$B$l\e(B") ("lo" "\e$B$m\e(B")
-("wa" "\e$B$o\e(B") ("wi" "\e$B$p\e(B") ("wu" "\e$B$&\e(B") ("we" "\e$B$q\e(B") ("wo" "\e$B$r\e(B")
-("n'" "\e$B$s\e(B")                                   
-("ga" "\e$B$,\e(B") ("gi" "\e$B$.\e(B") ("gu" "\e$B$0\e(B") ("ge" "\e$B$2\e(B") ("go" "\e$B$4\e(B")
-("za" "\e$B$6\e(B") ("zi" "\e$B$8\e(B") ("zu" "\e$B$:\e(B") ("ze" "\e$B$<\e(B") ("zo" "\e$B$>\e(B")
-("da" "\e$B$@\e(B") ("di" "\e$B$B\e(B") ("du" "\e$B$E\e(B") ("de" "\e$B$G\e(B") ("do" "\e$B$I\e(B")
-("ba" "\e$B$P\e(B") ("bi" "\e$B$S\e(B") ("bu" "\e$B$V\e(B") ("be" "\e$B$Y\e(B") ("bo" "\e$B$\\e(B")
-("pa" "\e$B$Q\e(B") ("pi" "\e$B$T\e(B") ("pu" "\e$B$W\e(B") ("pe" "\e$B$Z\e(B") ("po" "\e$B$]\e(B")
-
-("kya" ["\e$B$-$c\e(B"]) ("kyu" ["\e$B$-$e\e(B"]) ("kye" ["\e$B$-$'\e(B"]) ("kyo" ["\e$B$-$g\e(B"])
-("sya" ["\e$B$7$c\e(B"]) ("syu" ["\e$B$7$e\e(B"]) ("sye" ["\e$B$7$'\e(B"]) ("syo" ["\e$B$7$g\e(B"])
-("sha" ["\e$B$7$c\e(B"]) ("shu" ["\e$B$7$e\e(B"]) ("she" ["\e$B$7$'\e(B"]) ("sho" ["\e$B$7$g\e(B"])
-("cha" ["\e$B$A$c\e(B"]) ("chu" ["\e$B$A$e\e(B"]) ("che" ["\e$B$A$'\e(B"]) ("cho" ["\e$B$A$g\e(B"])
-("tya" ["\e$B$A$c\e(B"]) ("tyu" ["\e$B$A$e\e(B"]) ("tye" ["\e$B$A$'\e(B"]) ("tyo" ["\e$B$A$g\e(B"])
-("nya" ["\e$B$K$c\e(B"]) ("nyu" ["\e$B$K$e\e(B"]) ("nye" ["\e$B$K$'\e(B"]) ("nyo" ["\e$B$K$g\e(B"])
-("hya" ["\e$B$R$c\e(B"]) ("hyu" ["\e$B$R$e\e(B"]) ("hye" ["\e$B$R$'\e(B"]) ("hyo" ["\e$B$R$g\e(B"])
-("mya" ["\e$B$_$c\e(B"]) ("myu" ["\e$B$_$e\e(B"]) ("mye" ["\e$B$_$'\e(B"]) ("myo" ["\e$B$_$g\e(B"])
-("rya" ["\e$B$j$c\e(B"]) ("ryu" ["\e$B$j$e\e(B"]) ("rye" ["\e$B$j$'\e(B"]) ("ryo" ["\e$B$j$g\e(B"])
-("lya" ["\e$B$j$c\e(B"]) ("lyu" ["\e$B$j$e\e(B"]) ("lye" ["\e$B$j$'\e(B"]) ("lyo" ["\e$B$j$g\e(B"])
-("gya" ["\e$B$.$c\e(B"]) ("gyu" ["\e$B$.$e\e(B"]) ("gye" ["\e$B$.$'\e(B"]) ("gyo" ["\e$B$.$g\e(B"])
-("zya" ["\e$B$8$c\e(B"]) ("zyu" ["\e$B$8$e\e(B"]) ("zye" ["\e$B$8$'\e(B"]) ("zyo" ["\e$B$8$g\e(B"])
-("jya" ["\e$B$8$c\e(B"]) ("jyu" ["\e$B$8$e\e(B"]) ("jye" ["\e$B$8$'\e(B"]) ("jyo" ["\e$B$8$g\e(B"])
-( "ja" ["\e$B$8$c\e(B"]) ( "ju" ["\e$B$8$e\e(B"]) ( "je" ["\e$B$8$'\e(B"]) ( "jo" ["\e$B$8$g\e(B"])
-("bya" ["\e$B$S$c\e(B"]) ("byu" ["\e$B$S$e\e(B"]) ("bye" ["\e$B$S$'\e(B"]) ("byo" ["\e$B$S$g\e(B"])
-("pya" ["\e$B$T$c\e(B"]) ("pyu" ["\e$B$T$e\e(B"]) ("pye" ["\e$B$T$'\e(B"]) ("pyo" ["\e$B$T$g\e(B"])
-
-("kwa" ["\e$B$/$n\e(B"]) ("kwi" ["\e$B$/$#\e(B"]) ("kwe" ["\e$B$/$'\e(B"]) ("kwo" ["\e$B$/$)\e(B"])
-("tsa" ["\e$B$D$!\e(B"]) ("tsi" ["\e$B$D$#\e(B"]) ("tse" ["\e$B$D$'\e(B"]) ("tso" ["\e$B$D$)\e(B"])
-( "fa" ["\e$B$U$!\e(B"]) ( "fi" ["\e$B$U$#\e(B"]) ( "fe" ["\e$B$U$'\e(B"]) ( "fo" ["\e$B$U$)\e(B"])
-("gwa" ["\e$B$0$n\e(B"]) ("gwi" ["\e$B$0$#\e(B"]) ("gwe" ["\e$B$0$'\e(B"]) ("gwo" ["\e$B$0$)\e(B"])
-
-("dyi" ["\e$B$G$#\e(B"]) ("dyu" ["\e$B$I$%\e(B"]) ("dye" ["\e$B$G$'\e(B"]) ("dyo" ["\e$B$I$)\e(B"])
-("xwi" ["\e$B$&$#\e(B"])                  ("xwe" ["\e$B$&$'\e(B"]) ("xwo" ["\e$B$&$)\e(B"])
-
-("shi" "\e$B$7\e(B") ("tyi" ["\e$B$F$#\e(B"]) ("chi" "\e$B$A\e(B") ("tsu" "\e$B$D\e(B") ("ji" "\e$B$8\e(B")
-("fu"  "\e$B$U\e(B")
-("ye" ["\e$B$$$'\e(B"])
-
-("va" ["\e$B%t$!\e(B"]) ("vi" ["\e$B%t$#\e(B"]) ("vu" "\e$B%t\e(B") ("ve" ["\e$B%t$'\e(B"]) ("vo" ["\e$B%t$)\e(B"])
-
-("xa"  "\e$B$!\e(B") ("xi"  "\e$B$#\e(B") ("xu"  "\e$B$%\e(B") ("xe"  "\e$B$'\e(B") ("xo"  "\e$B$)\e(B")
-("xtu" "\e$B$C\e(B") ("xya" "\e$B$c\e(B") ("xyu" "\e$B$e\e(B") ("xyo" "\e$B$g\e(B") ("xwa" "\e$B$n\e(B")
-("xka" "\e$B%u\e(B") ("xke" "\e$B%v\e(B")
-
-("1" "\e$B#1\e(B") ("2" "\e$B#2\e(B") ("3" "\e$B#3\e(B") ("4" "\e$B#4\e(B") ("5" "\e$B#5\e(B")
-("6" "\e$B#6\e(B") ("7" "\e$B#7\e(B") ("8" "\e$B#8\e(B") ("9" "\e$B#9\e(B") ("0" "\e$B#0\e(B")
-
-("!" "\e$B!*\e(B") ("@" "\e$B!w\e(B") ("#" "\e$B!t\e(B") ("$" "\e$B!p\e(B") ("%" "\e$B!s\e(B")
-("^" "\e$B!0\e(B") ("&" "\e$B!u\e(B") ("*" "\e$B!v\e(B") ("(" "\e$B!J\e(B") (")" "\e$B!K\e(B")
-("-" "\e$B!<\e(B") ("=" "\e$B!a\e(B") ("`" "\e$B!.\e(B") ("\\" "\e$B!o\e(B") ("|" "\e$B!C\e(B")
-("_" "\e$B!2\e(B") ("+" "\e$B!\\e(B") ("~" "\e$B!1\e(B") ("[" "\e$B!V\e(B") ("]" "\e$B!W\e(B")
-("{" "\e$B!P\e(B") ("}" "\e$B!Q\e(B") (":" "\e$B!'\e(B") (";" "\e$B!(\e(B") ("\""  "\e$B!I\e(B")
-("'" "\e$B!G\e(B") ("." "\e$B!#\e(B") ("," "\e$B!"\e(B") ("<" "\e$B!c\e(B") (">" "\e$B!d\e(B")
-("?" "\e$B!)\e(B") ("/" "\e$B!?\e(B")
-
-("z1" "\e$B!{\e(B") ("z!" "\e$B!|\e(B")
-("z2" "\e$B"&\e(B") ("z@" "\e$B"'\e(B")
-("z3" "\e$B"$\e(B") ("z#" "\e$B"%\e(B")
-("z4" "\e$B""\e(B") ("z$" "\e$B"#\e(B")
-("z5" "\e$B!~\e(B") ("z%" "\e$B"!\e(B")
-("z6" "\e$B!y\e(B") ("z^" "\e$B!z\e(B")
-("z7" "\e$B!}\e(B") ("z&" "\e$B!r\e(B")
-("z8" "\e$B!q\e(B") ("z*" "\e$B!_\e(B")
-("z9" "\e$B!i\e(B") ("z(" "\e$B!Z\e(B")
-("z0" "\e$B!j\e(B") ("z)" "\e$B![\e(B")
-("z-" "\e$B!A\e(B") ("z_" "\e$B!h\e(B")
-("z=" "\e$B!b\e(B") ("z+" "\e$B!^\e(B")
-("z\\" "\e$B!@\e(B") ("z|" "\e$B!B\e(B")
-("z`" "\e$B!-\e(B") ("z~" "\e$B!/\e(B")
-
-("zq" "\e$B!T\e(B") ("zQ" "\e$B!R\e(B")
-("zw" "\e$B!U\e(B") ("zW" "\e$B!S\e(B")
-("zr" "\e$B!9\e(B") ("zR" "\e$B!8\e(B")
-("zt" "\e$B!:\e(B") ("zT" "\e$B!x\e(B")
-("zp" "\e$B")\e(B") ("zP" "\e$B",\e(B")
-("z[" "\e$B!X\e(B") ("z{" "\e$B!L\e(B")
-("z]" "\e$B!Y\e(B") ("z}" "\e$B!M\e(B")
-
-("zs" "\e$B!3\e(B") ("zS" "\e$B!4\e(B")
-("zd" "\e$B!5\e(B") ("zD" "\e$B!6\e(B")
-("zf" "\e$B!7\e(B") ("zF" "\e$B"*\e(B")
-("zg" "\e$B!>\e(B") ("zG" "\e$B!=\e(B")
-("zh" "\e$B"+\e(B")
-("zj" "\e$B"-\e(B")
-("zk" "\e$B",\e(B")
-("zl" "\e$B"*\e(B")
-("z;" "\e$B!+\e(B") ("z:" "\e$B!,\e(B")
-("z\'" "\e$B!F\e(B") ("z\"" "\e$B!H\e(B")
-
-("zx" ":-") ("zX" ":-)")
-("zc" "\e$B!;\e(B") ("zC" "\e$B!n\e(B")
-("zv" "\e$B"(\e(B") ("zV" "\e$B!`\e(B")
-("zb" "\e$B!k\e(B") ("zB" "\e$B"+\e(B")
-("zn" "\e$B!l\e(B") ("zN" "\e$B"-\e(B")
-("zm" "\e$B!m\e(B") ("zM" "\e$B".\e(B")
-("z," "\e$B!E\e(B") ("z<" "\e$B!e\e(B")
-("z." "\e$B!D\e(B") ("z>" "\e$B!f\e(B")
-("z/" "\e$B!&\e(B") ("z?" "\e$B!g\e(B")
-
-("\\\\" quail-japanese-self-insert-and-switch-to-alpha)
-("{{" quail-japanese-self-insert-and-switch-to-alpha)
-("}}" quail-japanese-self-insert-and-switch-to-alpha)
-
-("qq" quail-japanese-switch-package)
-("qz" quail-japanese-switch-package)
-
-)
-
-(quail-define-package
- "japanese-ascii" "Japanese" "Aa"
- nil
- "Temporary ASCII input mode while using Quail package `japanese'
-Type \"qq\" to go back to previous package."
- nil t t)
-
-(quail-define-rules ("qq" quail-japanese-switch-package))
-
-(quail-define-package
- "japanese-zenkaku" "Japanese" "\e$B#A\e(B"
- nil
- "Japanese zenkaku alpha numeric character input method
----- Special key bindings ----
-qq:    toggle between `japanese-zenkaku' and `japanese-ascii'
-qh:    use `japanese' package, \"qz\" puts you back to `japanese-zenkaku'
-"
- nil t t)
-
-(quail-define-rules
-
-(" " "\e$B!!\e(B") ("!" "\e$B!*\e(B") ("\"" "\e$B!m\e(B") ("#" "\e$B!t\e(B")
-("$" "\e$B!p\e(B") ("%" "\e$B!s\e(B") ("&" "\e$B!u\e(B") ("'" "\e$B!l\e(B")
-("(" "\e$B!J\e(B") (")" "\e$B!K\e(B") ("*" "\e$B!v\e(B") ("+" "\e$B!\\e(B")
-("," "\e$B!$\e(B") ("-" "\e$B!]\e(B") ("." "\e$B!%\e(B") ("/" "\e$B!?\e(B")
-("0" "\e$B#0\e(B") ("1" "\e$B#1\e(B") ("2" "\e$B#2\e(B") ("3" "\e$B#3\e(B")
-("4" "\e$B#4\e(B") ("5" "\e$B#5\e(B") ("6" "\e$B#6\e(B") ("7" "\e$B#7\e(B")
-("8" "\e$B#8\e(B") ("9" "\e$B#9\e(B") (":" "\e$B!'\e(B") (";" "\e$B!(\e(B")
-("<" "\e$B!c\e(B") ("=" "\e$B!a\e(B") (">" "\e$B!d\e(B") ("?" "\e$B!)\e(B")
-("@" "\e$B!w\e(B") ("A" "\e$B#A\e(B") ("B" "\e$B#B\e(B") ("C" "\e$B#C\e(B")
-("D" "\e$B#D\e(B") ("E" "\e$B#E\e(B") ("F" "\e$B#F\e(B") ("G" "\e$B#G\e(B")
-("H" "\e$B#H\e(B") ("I" "\e$B#I\e(B") ("J" "\e$B#J\e(B") ("K" "\e$B#K\e(B")
-("L" "\e$B#L\e(B") ("M" "\e$B#M\e(B") ("N" "\e$B#N\e(B") ("O" "\e$B#O\e(B")
-("P" "\e$B#P\e(B") ("Q" "\e$B#Q\e(B") ("R" "\e$B#R\e(B") ("S" "\e$B#S\e(B")
-("T" "\e$B#T\e(B") ("U" "\e$B#U\e(B") ("V" "\e$B#V\e(B") ("W" "\e$B#W\e(B")
-("X" "\e$B#X\e(B") ("Y" "\e$B#Y\e(B") ("Z" "\e$B#Z\e(B") ("[" "\e$B!N\e(B")
-("\\" "\e$B!o\e(B") ("]" "\e$B!O\e(B") ("^" "\e$B!0\e(B") ("_" "\e$B!2\e(B")
-("`" "\e$B!F\e(B") ("a" "\e$B#a\e(B") ("b" "\e$B#b\e(B") ("c" "\e$B#c\e(B")
-("d" "\e$B#d\e(B") ("e" "\e$B#e\e(B") ("f" "\e$B#f\e(B") ("g" "\e$B#g\e(B")
-("h" "\e$B#h\e(B") ("i" "\e$B#i\e(B") ("j" "\e$B#j\e(B") ("k" "\e$B#k\e(B")
-("l" "\e$B#l\e(B") ("m" "\e$B#m\e(B") ("n" "\e$B#n\e(B") ("o" "\e$B#o\e(B")
-("p" "\e$B#p\e(B") ("q" "\e$B#q\e(B") ("r" "\e$B#r\e(B") ("s" "\e$B#s\e(B")
-("t" "\e$B#t\e(B") ("u" "\e$B#u\e(B") ("v" "\e$B#v\e(B") ("w" "\e$B#w\e(B")
-("x" "\e$B#x\e(B") ("y" "\e$B#y\e(B") ("z" "\e$B#z\e(B") ("{" "\e$B!P\e(B")
-("|" "\e$B!C\e(B") ("}" "\e$B!Q\e(B") ("~" "\e$B!A\e(B") 
-
-("qq" quail-japanese-switch-package)
-("qh" quail-japanese-switch-package)
-)
-
-(defun quail-japanese-hankaku-update-translation (control-flag)
-  (cond ((eq control-flag t)
-        (insert (japanese-hankaku quail-current-str))
-        (quail-terminate-translation))
-       ((null control-flag)
-        (insert (if quail-current-str
-                    (japanese-hankaku quail-current-str)
-                  quail-current-key)))
-       (t                              ; i.e. (numberp control-flag)
-        (cond ((= (aref quail-current-key 0) ?n)
-               (insert ?\e(I]\e(B))
-              ((= (aref quail-current-key 0) (aref quail-current-key 1))
-               (insert ?\e(I/\e(B))
-              (t
-               (insert (aref quail-current-key 0))))
-        (setq unread-command-events
-              (list (aref quail-current-key control-flag)))
-        (quail-terminate-translation))))
-
-
-(quail-define-package
- "japanese-hankaku-kana"
- "Japanese" "\e(I1\e(B"
- nil
- "Japanese hankaku katakana input method by Roman transliteration
----- Special key bindings ----
-qq:    toggle between `japanese-hankaku-kana' and `japanese-ascii'
-"
- nil t t nil nil nil nil nil
- 'quail-japanese-hankaku-update-translation)
-
-;; Use the same map as that of `japanese'.
-(setcar (cdr (cdr quail-current-package))
-       (nth 2 (assoc "japanese" quail-package-alist)))
-
-(quail-define-package
- "japanese-hiragana" "Japanese" "\e$B$"\e(B"
- nil
- "Japanese hiragana input method by Roman transliteration"
- nil t t nil nil nil nil nil
- 'quail-japanese-update-translation)
-
-;; Use the same map as that of `japanese'.
-(setcar (cdr (cdr quail-current-package))
-       (nth 2 (assoc "japanese" quail-package-alist)))
-
-;; Update Quail translation region while converting Hiragana to Katakana.
-(defun quail-japanese-katakana-update-translation (control-flag)
-  (cond ((eq control-flag t)
-        (insert (japanese-katakana quail-current-str))
-        (quail-terminate-translation))
-       ((null control-flag)
-        (insert (if quail-current-str
-                    (japanese-katakana quail-current-str)
-                  quail-current-key)))
-       (t                              ; i.e. (numberp control-flag)
-        (cond ((= (aref quail-current-key 0) ?n)
-               (insert ?\e$B%s\e(B))
-              ((= (aref quail-current-key 0) (aref quail-current-key 1))
-               (insert ?\e$B%C\e(B))
-              (t
-               (insert (aref quail-current-key 0))))
-        (setq unread-command-events
-              (list (aref quail-current-key control-flag)))
-        (quail-terminate-translation))))
-
-(quail-define-package 
- "japanese-katakana" "Japanese" "\e$B%"\e(B"
- nil
- "Japanese katakana input method by Roman transliteration"
- nil t t nil nil nil nil nil
- 'quail-japanese-katakana-update-translation)
-
-;; Use the same map as that of `japanese'.
-(setcar (cdr (cdr quail-current-package))
-       (nth 2 (assoc "japanese" quail-package-alist)))
+;;; japanese.el --- Quail package for inputting Japanese  -*-coding: iso-2022-7bit;-*-
+
+;; Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010
+;;   Free Software Foundation, Inc.
+;; Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
+;;   2006, 2007, 2008, 2009, 2010
+;;   National Institute of Advanced Industrial Science and Technology (AIST)
+;;   Registration Number H14PRO021
+
+;; Keywords: multilingual, input method, Japanese
+
+;; This file is part of GNU Emacs.
+
+;; GNU Emacs 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 3 of the License, or
+;; (at your option) any later version.
+
+;; GNU Emacs 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.  If not, see <http://www.gnu.org/licenses/>.
+
+;;; Commentary:
+
+;;; Code:
+
+(require 'quail)
+(require 'kkc)
+
+(defvar quail-japanese-use-double-n nil
+  "If non-nil, use type \"nn\" to insert \e$B$s\e(B.")
+
+;; Update Quail translation region while considering Japanese bizarre
+;; translation rules.
+(defun quail-japanese-update-translation (control-flag)
+  (if (null control-flag)
+      (setq quail-current-str
+           (if (/= (aref quail-current-key 0) ?q)
+               (or quail-current-str quail-current-key)
+             ""))
+    (if (integerp control-flag)
+       (if (= control-flag 0)
+           (setq quail-current-str (aref quail-current-key 0))
+         (cond ((= (aref quail-current-key 0) ?n)
+                (setq quail-current-str ?\e$B$s\e(B)
+                (if (and quail-japanese-use-double-n
+                         (= (aref quail-current-key 1) ?n))
+                    (setq control-flag t)))
+               ((= (aref quail-current-key 0) (aref quail-current-key 1))
+                (setq quail-current-str ?\e$B$C\e(B))
+               (t
+                (setq quail-current-str (aref quail-current-key 0))))
+         (if (integerp control-flag)
+             (setq unread-command-events
+                   (list (aref quail-current-key control-flag)))))))
+  control-flag)
+
+;; Convert Hiragana <-> Katakana in the current translation region.
+(defun quail-japanese-toggle-kana ()
+  (interactive)
+  (setq quail-translating nil)
+  (let ((start (overlay-start quail-conv-overlay))
+       (end (overlay-end quail-conv-overlay)))
+    (save-excursion
+      (goto-char start)
+      (if (re-search-forward "\\cH" end t)
+         (japanese-katakana-region start end)
+       (japanese-hiragana-region start end)))
+    (setq quail-conversion-str
+         (buffer-substring (overlay-start quail-conv-overlay)
+                           (overlay-end quail-conv-overlay)))))
+
+;; Convert Hiragana in the current translation region to Kanji by KKC
+;; (Kana Kanji Converter) utility.
+(defun quail-japanese-kanji-kkc ()
+  (interactive)
+  (when (= (char-before (overlay-end quail-conv-overlay)) ?n)
+    ;; The last char is `n'.  We had better convert it to `\e$B$s\e(B'
+    ;; before kana-kanji conversion.
+    (goto-char (1- (overlay-end quail-conv-overlay)))
+    (insert ?\e$B$s\e(B)
+    (delete-char 1))
+  (let* ((from (copy-marker (overlay-start quail-conv-overlay)))
+        (len (- (overlay-end quail-conv-overlay) from)))
+    (quail-delete-overlays)
+    (setq quail-current-str nil)
+    (unwind-protect
+       (let ((result (kkc-region from (+ from len))))
+         (move-overlay quail-conv-overlay from (point))
+         (setq quail-conversion-str (buffer-substring from (point)))
+         (if (= (+ from result) (point))
+             (setq quail-converting nil))
+         (setq quail-translating nil))
+      (set-marker from nil))))
+
+(defun quail-japanese-self-insert-and-switch-to-alpha (key idx)
+  (quail-delete-region)
+  (setq unread-command-events (list (aref key (1- idx))))
+  (quail-japanese-switch-package "q" 1))
+
+(defvar quail-japanese-switch-table
+  '((?z . "japanese-zenkaku")
+    (?k . "japanese-hankaku-kana")
+    (?h . "japanese")
+    (?q . ("japanese-ascii"))))
+
+(defvar quail-japanese-package-saved nil)
+(make-variable-buffer-local 'quail-japanese-package-saved)
+(put 'quail-japanese-package-saved 'permanent-local t)
+
+(defun quail-japanese-switch-package (key idx)
+  (quail-delete-region)
+  (setq quail-current-str nil
+       quail-converting nil
+       quail-conversion-str "")
+  (let ((pkg (cdr (assq (aref key (1- idx)) quail-japanese-switch-table))))
+    (if (null pkg)
+       (quail-error "No package to be switched")
+      (if (stringp pkg)
+         (activate-input-method pkg)
+       (if (string= (car pkg) current-input-method)
+           (if quail-japanese-package-saved
+               (activate-input-method quail-japanese-package-saved))
+         (setq quail-japanese-package-saved current-input-method)
+         (activate-input-method (car pkg))))))
+  (throw 'quail-tag nil))
+
+(defvar quail-japanese-transliteration-rules
+  '(( "a" "\e$B$"\e(B") ( "i" "\e$B$$\e(B") ( "u" "\e$B$&\e(B") ( "e" "\e$B$(\e(B") ( "o" "\e$B$*\e(B")
+    ("ka" "\e$B$+\e(B") ("ki" "\e$B$-\e(B") ("ku" "\e$B$/\e(B") ("ke" "\e$B$1\e(B") ("ko" "\e$B$3\e(B")
+    ("sa" "\e$B$5\e(B") ("si" "\e$B$7\e(B") ("su" "\e$B$9\e(B") ("se" "\e$B$;\e(B") ("so" "\e$B$=\e(B")
+    ("ta" "\e$B$?\e(B") ("ti" "\e$B$A\e(B") ("tu" "\e$B$D\e(B") ("te" "\e$B$F\e(B") ("to" "\e$B$H\e(B")
+    ("na" "\e$B$J\e(B") ("ni" "\e$B$K\e(B") ("nu" "\e$B$L\e(B") ("ne" "\e$B$M\e(B") ("no" "\e$B$N\e(B")
+    ("ha" "\e$B$O\e(B") ("hi" "\e$B$R\e(B") ("hu" "\e$B$U\e(B") ("he" "\e$B$X\e(B") ("ho" "\e$B$[\e(B")
+    ("ma" "\e$B$^\e(B") ("mi" "\e$B$_\e(B") ("mu" "\e$B$`\e(B") ("me" "\e$B$a\e(B") ("mo" "\e$B$b\e(B")
+    ("ya" "\e$B$d\e(B")             ("yu" "\e$B$f\e(B")             ("yo" "\e$B$h\e(B")
+    ("ra" "\e$B$i\e(B") ("ri" "\e$B$j\e(B") ("ru" "\e$B$k\e(B") ("re" "\e$B$l\e(B") ("ro" "\e$B$m\e(B")
+    ("la" "\e$B$i\e(B") ("li" "\e$B$j\e(B") ("lu" "\e$B$k\e(B") ("le" "\e$B$l\e(B") ("lo" "\e$B$m\e(B")
+    ("wa" "\e$B$o\e(B") ("wi" "\e$B$p\e(B") ("wu" "\e$B$&\e(B") ("we" "\e$B$q\e(B") ("wo" "\e$B$r\e(B")
+    ("n'" "\e$B$s\e(B")
+    ("ga" "\e$B$,\e(B") ("gi" "\e$B$.\e(B") ("gu" "\e$B$0\e(B") ("ge" "\e$B$2\e(B") ("go" "\e$B$4\e(B")
+    ("za" "\e$B$6\e(B") ("zi" "\e$B$8\e(B") ("zu" "\e$B$:\e(B") ("ze" "\e$B$<\e(B") ("zo" "\e$B$>\e(B")
+    ("da" "\e$B$@\e(B") ("di" "\e$B$B\e(B") ("du" "\e$B$E\e(B") ("de" "\e$B$G\e(B") ("do" "\e$B$I\e(B")
+    ("ba" "\e$B$P\e(B") ("bi" "\e$B$S\e(B") ("bu" "\e$B$V\e(B") ("be" "\e$B$Y\e(B") ("bo" "\e$B$\\e(B")
+    ("pa" "\e$B$Q\e(B") ("pi" "\e$B$T\e(B") ("pu" "\e$B$W\e(B") ("pe" "\e$B$Z\e(B") ("po" "\e$B$]\e(B")
+
+    ("kya" ["\e$B$-$c\e(B"]) ("kyu" ["\e$B$-$e\e(B"]) ("kye" ["\e$B$-$'\e(B"]) ("kyo" ["\e$B$-$g\e(B"])
+    ("sya" ["\e$B$7$c\e(B"]) ("syu" ["\e$B$7$e\e(B"]) ("sye" ["\e$B$7$'\e(B"]) ("syo" ["\e$B$7$g\e(B"])
+    ("sha" ["\e$B$7$c\e(B"]) ("shu" ["\e$B$7$e\e(B"]) ("she" ["\e$B$7$'\e(B"]) ("sho" ["\e$B$7$g\e(B"])
+    ("cha" ["\e$B$A$c\e(B"]) ("chu" ["\e$B$A$e\e(B"]) ("che" ["\e$B$A$'\e(B"]) ("cho" ["\e$B$A$g\e(B"])
+    ("tya" ["\e$B$A$c\e(B"]) ("tyu" ["\e$B$A$e\e(B"]) ("tye" ["\e$B$A$'\e(B"]) ("tyo" ["\e$B$A$g\e(B"])
+    ("nya" ["\e$B$K$c\e(B"]) ("nyu" ["\e$B$K$e\e(B"]) ("nye" ["\e$B$K$'\e(B"]) ("nyo" ["\e$B$K$g\e(B"])
+    ("hya" ["\e$B$R$c\e(B"]) ("hyu" ["\e$B$R$e\e(B"]) ("hye" ["\e$B$R$'\e(B"]) ("hyo" ["\e$B$R$g\e(B"])
+    ("mya" ["\e$B$_$c\e(B"]) ("myu" ["\e$B$_$e\e(B"]) ("mye" ["\e$B$_$'\e(B"]) ("myo" ["\e$B$_$g\e(B"])
+    ("rya" ["\e$B$j$c\e(B"]) ("ryu" ["\e$B$j$e\e(B"]) ("rye" ["\e$B$j$'\e(B"]) ("ryo" ["\e$B$j$g\e(B"])
+    ("lya" ["\e$B$j$c\e(B"]) ("lyu" ["\e$B$j$e\e(B"]) ("lye" ["\e$B$j$'\e(B"]) ("lyo" ["\e$B$j$g\e(B"])
+    ("gya" ["\e$B$.$c\e(B"]) ("gyu" ["\e$B$.$e\e(B"]) ("gye" ["\e$B$.$'\e(B"]) ("gyo" ["\e$B$.$g\e(B"])
+    ("zya" ["\e$B$8$c\e(B"]) ("zyu" ["\e$B$8$e\e(B"]) ("zye" ["\e$B$8$'\e(B"]) ("zyo" ["\e$B$8$g\e(B"])
+    ("jya" ["\e$B$8$c\e(B"]) ("jyu" ["\e$B$8$e\e(B"]) ("jye" ["\e$B$8$'\e(B"]) ("jyo" ["\e$B$8$g\e(B"])
+    ( "ja" ["\e$B$8$c\e(B"]) ( "ju" ["\e$B$8$e\e(B"]) ( "je" ["\e$B$8$'\e(B"]) ( "jo" ["\e$B$8$g\e(B"])
+    ("bya" ["\e$B$S$c\e(B"]) ("byu" ["\e$B$S$e\e(B"]) ("bye" ["\e$B$S$'\e(B"]) ("byo" ["\e$B$S$g\e(B"])
+    ("pya" ["\e$B$T$c\e(B"]) ("pyu" ["\e$B$T$e\e(B"]) ("pye" ["\e$B$T$'\e(B"]) ("pyo" ["\e$B$T$g\e(B"])
+
+    ("kwa" ["\e$B$/$n\e(B"]) ("kwi" ["\e$B$/$#\e(B"]) ("kwe" ["\e$B$/$'\e(B"]) ("kwo" ["\e$B$/$)\e(B"])
+    ("tsa" ["\e$B$D$!\e(B"]) ("tsi" ["\e$B$D$#\e(B"]) ("tse" ["\e$B$D$'\e(B"]) ("tso" ["\e$B$D$)\e(B"])
+    ( "fa" ["\e$B$U$!\e(B"]) ( "fi" ["\e$B$U$#\e(B"]) ( "fe" ["\e$B$U$'\e(B"]) ( "fo" ["\e$B$U$)\e(B"])
+    ("gwa" ["\e$B$0$n\e(B"]) ("gwi" ["\e$B$0$#\e(B"]) ("gwe" ["\e$B$0$'\e(B"]) ("gwo" ["\e$B$0$)\e(B"])
+
+    ("dyi" ["\e$B$G$#\e(B"]) ("dyu" ["\e$B$I$%\e(B"]) ("dye" ["\e$B$G$'\e(B"]) ("dyo" ["\e$B$I$)\e(B"])
+    ("xwi" ["\e$B$&$#\e(B"])                  ("xwe" ["\e$B$&$'\e(B"]) ("xwo" ["\e$B$&$)\e(B"])
+
+    ("shi" "\e$B$7\e(B") ("tyi" ["\e$B$F$#\e(B"]) ("chi" "\e$B$A\e(B") ("tsu" "\e$B$D\e(B") ("ji" "\e$B$8\e(B")
+    ("fu"  "\e$B$U\e(B")
+    ("ye" ["\e$B$$$'\e(B"])
+
+    ("va" ["\e$B%t$!\e(B"]) ("vi" ["\e$B%t$#\e(B"]) ("vu" "\e$B%t\e(B") ("ve" ["\e$B%t$'\e(B"]) ("vo" ["\e$B%t$)\e(B"])
+
+    ("xa"  "\e$B$!\e(B") ("xi"  "\e$B$#\e(B") ("xu"  "\e$B$%\e(B") ("xe"  "\e$B$'\e(B") ("xo"  "\e$B$)\e(B")
+    ("xtu" "\e$B$C\e(B") ("xya" "\e$B$c\e(B") ("xyu" "\e$B$e\e(B") ("xyo" "\e$B$g\e(B") ("xwa" "\e$B$n\e(B")
+    ("xka" "\e$B%u\e(B") ("xke" "\e$B%v\e(B")
+
+    ("1" "\e$B#1\e(B") ("2" "\e$B#2\e(B") ("3" "\e$B#3\e(B") ("4" "\e$B#4\e(B") ("5" "\e$B#5\e(B")
+    ("6" "\e$B#6\e(B") ("7" "\e$B#7\e(B") ("8" "\e$B#8\e(B") ("9" "\e$B#9\e(B") ("0" "\e$B#0\e(B")
+
+    ("!" "\e$B!*\e(B") ("@" "\e$B!w\e(B") ("#" "\e$B!t\e(B") ("$" "\e$B!p\e(B") ("%" "\e$B!s\e(B")
+    ("^" "\e$B!0\e(B") ("&" "\e$B!u\e(B") ("*" "\e$B!v\e(B") ("(" "\e$B!J\e(B") (")" "\e$B!K\e(B")
+    ("-" "\e$B!<\e(B") ("=" "\e$B!a\e(B") ("`" "\e$B!.\e(B") ("\\" "\e$B!o\e(B") ("|" "\e$B!C\e(B")
+    ("_" "\e$B!2\e(B") ("+" "\e$B!\\e(B") ("~" "\e$B!1\e(B") ("[" "\e$B!V\e(B") ("]" "\e$B!W\e(B")
+    ("{" "\e$B!P\e(B") ("}" "\e$B!Q\e(B") (":" "\e$B!'\e(B") (";" "\e$B!(\e(B") ("\""  "\e$B!I\e(B")
+    ("'" "\e$B!G\e(B") ("." "\e$B!#\e(B") ("," "\e$B!"\e(B") ("<" "\e$B!c\e(B") (">" "\e$B!d\e(B")
+    ("?" "\e$B!)\e(B") ("/" "\e$B!?\e(B")
+
+    ("z1" "\e$B!{\e(B") ("z!" "\e$B!|\e(B")
+    ("z2" "\e$B"&\e(B") ("z@" "\e$B"'\e(B")
+    ("z3" "\e$B"$\e(B") ("z#" "\e$B"%\e(B")
+    ("z4" "\e$B""\e(B") ("z$" "\e$B"#\e(B")
+    ("z5" "\e$B!~\e(B") ("z%" "\e$B"!\e(B")
+    ("z6" "\e$B!y\e(B") ("z^" "\e$B!z\e(B")
+    ("z7" "\e$B!}\e(B") ("z&" "\e$B!r\e(B")
+    ("z8" "\e$B!q\e(B") ("z*" "\e$B!_\e(B")
+    ("z9" "\e$B!i\e(B") ("z(" "\e$B!Z\e(B")
+    ("z0" "\e$B!j\e(B") ("z)" "\e$B![\e(B")
+    ("z-" "\e$B!A\e(B") ("z_" "\e$B!h\e(B")
+    ("z=" "\e$B!b\e(B") ("z+" "\e$B!^\e(B")
+    ("z\\" "\e$B!@\e(B") ("z|" "\e$B!B\e(B")
+    ("z`" "\e$B!-\e(B") ("z~" "\e$B!/\e(B")
+
+    ("zq" "\e$B!T\e(B") ("zQ" "\e$B!R\e(B")
+    ("zw" "\e$B!U\e(B") ("zW" "\e$B!S\e(B")
+    ("zr" "\e$B!9\e(B") ("zR" "\e$B!8\e(B")
+    ("zt" "\e$B!:\e(B") ("zT" "\e$B!x\e(B")
+    ("zp" "\e$B")\e(B") ("zP" "\e$B",\e(B")
+    ("z[" "\e$B!X\e(B") ("z{" "\e$B!L\e(B")
+    ("z]" "\e$B!Y\e(B") ("z}" "\e$B!M\e(B")
+
+    ("zs" "\e$B!3\e(B") ("zS" "\e$B!4\e(B")
+    ("zd" "\e$B!5\e(B") ("zD" "\e$B!6\e(B")
+    ("zf" "\e$B!7\e(B") ("zF" "\e$B"*\e(B")
+    ("zg" "\e$B!>\e(B") ("zG" "\e$B!=\e(B")
+    ("zh" "\e$B"+\e(B")
+    ("zj" "\e$B"-\e(B")
+    ("zk" "\e$B",\e(B")
+    ("zl" "\e$B"*\e(B")
+    ("z;" "\e$B!+\e(B") ("z:" "\e$B!,\e(B")
+    ("z\'" "\e$B!F\e(B") ("z\"" "\e$B!H\e(B")
+
+    ("zx" [":-"]) ("zX" [":-)"])
+    ("zc" "\e$B!;\e(B") ("zC" "\e$B!n\e(B")
+    ("zv" "\e$B"(\e(B") ("zV" "\e$B!`\e(B")
+    ("zb" "\e$B!k\e(B") ("zB" "\e$B"+\e(B")
+    ("zn" "\e$B!l\e(B") ("zN" "\e$B"-\e(B")
+    ("zm" "\e$B!m\e(B") ("zM" "\e$B".\e(B")
+    ("z," "\e$B!E\e(B") ("z<" "\e$B!e\e(B")
+    ("z." "\e$B!D\e(B") ("z>" "\e$B!f\e(B")
+    ("z/" "\e$B!&\e(B") ("z?" "\e$B!g\e(B")
+
+    ("\\\\" quail-japanese-self-insert-and-switch-to-alpha)
+    ("{{" quail-japanese-self-insert-and-switch-to-alpha)
+    ("}}" quail-japanese-self-insert-and-switch-to-alpha)
+
+    ("qq" quail-japanese-switch-package)
+    ("qz" quail-japanese-switch-package)
+    ))
+
+
+;; \e$B%m!<%^;zF~NO5Z$S2>L>4A;zJQ49$K$h$kF|K\8lF~NO%a%=%C%I\e(B
+;;
+;; \e$B$3$NF~NO%a%=%C%I$G$NF|K\8l$NF~NO$OFs$D$N%9%F!<%8!V%m!<%^;z2>L>JQ49!W\e(B
+;; \e$B$H!V2>L>4A;zJQ49!W$+$i$J$k!#:G=i$O%m!<%^;z2>L>JQ49$N%9%F!<%8$G!"%9\e(B
+;; \e$B%Z!<%9%-!<$r2!$9$3$H$K$h$j!"<!$N%9%F!<%8!V2>L>4A;zJQ49!W$X?J$`!#\e(B
+;;
+;; \e$B!V%m!<%^;z2>L>JQ49!W\e(B
+;;
+;; \e$BJ?2>L>$O>.J8;z%-!<!JNs!K$rBG$D$3$H$K$h$jF~NO!#6gFIE@!"3g8LN`$OBP1~\e(B
+;; \e$B$9$k1Q;z%-!<$rBG$D$3$H$K$h$jF~NO!#$=$NB>$N%7%s%\%k$O\e(B `z' \e$B$KB3$1$F2?\e(B
+;; \e$B$l$+$N%-!<$rBG$D$3$H$K$h$jF~NO!#2<$KA4$F$N2DG=$J%-!<%7!<%1%s%9%j%9\e(B
+;; \e$B%H%"%C%W$5$l$F$$$k!#F~NO$5$l$?J8;z$O2<@~$G<($5$l$k!#\e(B
+;;
+;; \e$B$5$i$K0J2<$N%-!<$GFCJL$J=hM}$r9T$&!#\e(B
+;;
+;; K   \e$BJ?2>L>$rJR2>L>$K!"$"$k$$$OJR2>L>$rJ?2>L>$KJQ49\e(B
+;; qq  \e$B$3$NF~NO%a%=%C%I$H\e(B `japanese-ascii' \e$BF~NO%a%=%C%I$r%H%0%k@ZBX\e(B
+;; qz  `japanese-zenkaku' \e$BF~NO%a%=%C%I$K%7%U%H\e(B
+;;     qh \e$B$HBG$F$P85$KLa$k\e(B
+;; RET \e$B8=:_$NF~NOJ8;zNs$r3NDj\e(B
+;; SPC \e$B2>L>4A;zJQ49$K?J$`\e(B
+;;
+;; `japanese-ascii' \e$BF~NO%a%=%C%I$O\e(B ASCII \e$BJ8;z$rF~NO$9$k$N$K;H$&!#$3$l\e(B
+;; \e$B$OF~NO%a%=%C%I$r%*%U$K$9$k$N$H$[$H$s$IF1$8$G$"$k!#0[$J$k$N$O\e(B qq \e$B$H\e(B
+;; \e$BBG$D$3$H$K$h$j!"\e(B`japanese' \e$BF~NO%a%=%C%I$KLa$l$kE@$G$"$k!#\e(B
+;;
+;; `japanese-zenkaku' \e$BF~NO%a%=%C%I$OA43Q1Q?t;z$rF~NO$9$k$N$K;H$&!#\e(B
+;;
+;; \e$B!V%m!<%^;z2>L>JQ49!W%9%F!<%8$G$N%-!<%7!<%1%s%9$N%j%9%H$O:G8e$KIU$1\e(B
+;; \e$B$F$"$k!#\e(B
+;;
+;; \e$B!V2>L>4A;zJQ49!W\e(B
+;;
+;; \e$B$3$N%9%F!<%8$G$O!"A0%9%F!<%8$GF~NO$5$l$?J8;zNs$r2>L>4A;zJQ49$9$k!#\e(B
+;; \e$BJQ49$5$l$?J8;zNs$O!"CmL\J8@a!JH?E>I=<(!K$H;D$j$NF~NO!J2<@~I=<(!K$K\e(B
+;; \e$BJ,$1$i$l$k!#CmL\J8@a$KBP$7$F$O0J2<$N%3%^%s%I$,;H$($k!#\e(B
+;;
+;; SPC, C-n    kkc-next
+;;     \e$B<!$NJQ498uJd$rI=<(\e(B
+;;     kkc-show-conversion-list-count \e$B0J>eB3$1$FBG$F$P!"JQ498uJd%j%9\e(B
+;;     \e$B%H$r%(%3!<%(%j%"$KI=<(\e(B
+;; C-p         kkc-prev
+;;     \e$BA0$NJQ498uJd$rI=<(\e(B
+;;     kkc-show-conversion-list-count \e$B0J>eB3$1$FBG$F$P!"JQ498uJd%j%9\e(B
+;;     \e$B%H$r%(%3!<%(%j%"$KI=<(\e(B
+;; l           kkc-show-conversion-list-or-next-group
+;;     \e$B:G9b#1#08D$^$G$NJQ498uJd$r%(%3!<%(%j%"$KI=<(!#\e(B
+;;     \e$BB3$1$FBG$?$l$l$P!"<!$N#1#08uJd$rI=<(!#\e(B
+;; L           kkc-show-conversion-list-or-prev-group
+;;     \e$B:G9b#1#08D$^$G$NJQ498uJd$r%(%3!<%(%j%"$KI=<(!#\e(B
+;;     \e$BB3$1$FBG$?$l$l$P!"A0$N#1#08uJd$rI=<(!#\e(B
+;; 0..9                kkc-select-from-list
+;;     \e$BBG$?$l$??t;z$NJQ498uJd$rA*Br\e(B
+;; H           kkc-hiragana
+;;     \e$BCmL\J8@a$rJ?2>L>$KJQ49\e(B
+;; K           kkc-katakana
+;;     \e$BCmL\J8@a$rJR2>L>$KJQ49\e(B
+;; C-o         kkc-longer
+;;     \e$BCmL\J8@a$r8e$m$K0lJ8;z?-$P$9\e(B
+;; C-i         kkc-shorter
+;;     \e$BCmL\J8@a$r8e$m$+$i0lJ8;z=L$a$k\e(B
+;; C-f         kkc-next-phrase
+;;     \e$BCmL\J8@a$r3NDj$5$;$k!#$b$7;D$j$NF~NO$,$^$@$"$l$P!":G=i$NJ8@a$r\e(B
+;;     \e$BA*Br$7!"$=$l$rCmL\J8@a$H$7!"$=$N:G=i$NJQ498uJd$rI=<($9$k!#\e(B
+;; DEL, C-c    kkc-cancel
+;;     \e$B2>L>4A;zJQ49$r%-%c%s%;%k$7!"%m!<%^;z2>L>JQ49$N%9%F!<%8$KLa$k!#\e(B
+;; return              kkc-terminate
+;;     \e$BA4J8@a$r3NDj$5$;$k!#\e(B
+;; C-SPC, C-@  kkc-first-char-only
+;;     \e$B:G=i$NJ8;z$r3NDj$5$;!";D$j$O:o=|$9$k!#\e(B
+;; C-h         kkc-help
+;;     \e$B$3$l$i$N%-!<%P%$%s%I$N%j%9%H$rI=<($9$k!#$"\e(B
+
+(quail-define-package
+ "japanese" "Japanese" "A\e$B$"\e(B"
+ nil
+ "Japanese input method by Roman transliteration and Kana-Kanji conversion.
+
+When you use this input method, text entry proceeds in two stages:
+Roman-Kana transliteration and Kana-Kanji conversion.  When you start
+to enter text, you are in the first stage, Roman-Kana transliteration.
+Type SPC to proceed to the next stage, Kana-Kanji conversion.
+
+:: Roman-Kana transliteration ::
+
+You can input any Hiragana character as a sequence of lower-case
+letters, Japanese punctuation characters by typing punctuation keys,
+Japanese symbols by typing `z' followed by another key.  See below for
+a list of all available sequences.  The characters you input are
+underlined.
+
+In addition, the following keys provide special effects:
+
+K      Change Hiragana to Katakana or Katakana to Hiragana.
+qq     Toggle between this input method and the input method `japanese-ascii'.
+qz     Shift to the input method `japanese-zenkaku'.
+       Typing \"qh\" will put you back to this input method.
+RET    Accept the current character sequence.
+SPC    Proceed to the next stage, Kana-Kanji conversion.
+
+The input method `japanese-ascii' is used to enter ASCII characters.
+This is almost the same as turning off the input method.  The only
+difference is that typing `qq' will put you back into the Japanese
+input method.
+
+The input method `japanese-zenkaku' is used to enter full width
+JISX0208 characters corresponding to typed ASCII characters.
+
+List of the all key sequences for Roman-Kana transliteration is shown
+at the tail.
+
+:: Kana-Kanji conversion ::
+
+You can convert the current Japanese characters (underlined) to
+Kana-Kanji mixed text.  In this stage, the converted text is divided
+into two parts, the current phrase (highlighted) and the remaining
+input (underlined).  The following commands can be used on the
+current phrase.
+
+SPC, C-n       kkc-next
+       Show the next candidate for the current phrase.
+       If successively typed `kkc-show-conversion-list-count' times,
+       conversion candidates are shown in the echo area.
+C-p            kkc-prev
+       Show the previous candidate for the current phrase.
+       If successively typed `kkc-show-conversion-list-count' times,
+       conversion candidates are shown in the echo area.
+l              kkc-show-conversion-list-or-next-group
+       Show at most 10 candidates for the current phrase in echo area.
+       If typed repeatedly, show the next 10 candidates.
+L              kkc-show-conversion-list-or-prev-group
+       Show at most 10 candidates for the current phrase in echo area.
+       If typed repeatedly, show the previous 10 candidates.
+0..9           kkc-select-from-list
+       Select a candidate corresponding to the typed number.
+H              kkc-hiragana
+       Convert the current phrase to Hiragana
+K              kkc-katakana
+       Convert the current phrase to Katakana
+C-o            kkc-longer
+       Extend the current phrase; pull in the first character of
+       the remaining input.
+C-i            kkc-shorter
+       Contract the current phrase; drop its last character
+       back into the remaining input.
+C-f            kkc-next-phrase
+       Accept the current phrase.  If there remains input, select
+       the first phrase as the current one, and show the first
+       candidate for the conversion.
+DEL, C-c       kkc-cancel
+       Cancel the conversion, shift back to the Roman-Kana
+       transliteration.
+return         kkc-terminate
+       Accept the whole conversion.
+C-SPC, C-@     kkc-first-char-only
+       Accept the first character of the current conversion,
+       delete the remaining input.
+C-h            kkc-help
+       List these key bindings.
+"
+ nil t t nil nil nil nil nil
+ 'quail-japanese-update-translation
+ '(("K" . quail-japanese-toggle-kana)
+   (" " . quail-japanese-kanji-kkc)
+   ("\C-m" . quail-no-conversion)
+   ([return] . quail-no-conversion))
+ )
+
+(dolist (elt quail-japanese-transliteration-rules)
+  (quail-defrule (car elt) (nth 1 elt)))
+
+(quail-define-package
+ "japanese-ascii" "Japanese" "Aa"
+ nil
+ "Temporary ASCII input mode used within the input method `japanese'.
+Type \"qq\" to go back to previous input method."
+ nil t t)
+
+(quail-define-rules ("qq" quail-japanese-switch-package))
+
+(quail-define-package
+ "japanese-zenkaku" "Japanese" "\e$B#A\e(B"
+ nil
+ "Japanese zenkaku alpha numeric character input method.
+---- Special key bindings ----
+qq:    toggle between this input method and the input method `japanese-ascii'.
+qh:    shift to the input method `japanese',
+       typing \"qz\" puts you back to this input method.
+"
+ nil t t)
+
+(quail-define-rules
+
+(" " "\e$B!!\e(B") ("!" "\e$B!*\e(B") ("\"" "\e$B!m\e(B") ("#" "\e$B!t\e(B")
+("$" "\e$B!p\e(B") ("%" "\e$B!s\e(B") ("&" "\e$B!u\e(B") ("'" "\e$B!l\e(B")
+("(" "\e$B!J\e(B") (")" "\e$B!K\e(B") ("*" "\e$B!v\e(B") ("+" "\e$B!\\e(B")
+("," "\e$B!$\e(B") ("-" "\e$B!]\e(B") ("." "\e$B!%\e(B") ("/" "\e$B!?\e(B")
+("0" "\e$B#0\e(B") ("1" "\e$B#1\e(B") ("2" "\e$B#2\e(B") ("3" "\e$B#3\e(B")
+("4" "\e$B#4\e(B") ("5" "\e$B#5\e(B") ("6" "\e$B#6\e(B") ("7" "\e$B#7\e(B")
+("8" "\e$B#8\e(B") ("9" "\e$B#9\e(B") (":" "\e$B!'\e(B") (";" "\e$B!(\e(B")
+("<" "\e$B!c\e(B") ("=" "\e$B!a\e(B") (">" "\e$B!d\e(B") ("?" "\e$B!)\e(B")
+("@" "\e$B!w\e(B") ("A" "\e$B#A\e(B") ("B" "\e$B#B\e(B") ("C" "\e$B#C\e(B")
+("D" "\e$B#D\e(B") ("E" "\e$B#E\e(B") ("F" "\e$B#F\e(B") ("G" "\e$B#G\e(B")
+("H" "\e$B#H\e(B") ("I" "\e$B#I\e(B") ("J" "\e$B#J\e(B") ("K" "\e$B#K\e(B")
+("L" "\e$B#L\e(B") ("M" "\e$B#M\e(B") ("N" "\e$B#N\e(B") ("O" "\e$B#O\e(B")
+("P" "\e$B#P\e(B") ("Q" "\e$B#Q\e(B") ("R" "\e$B#R\e(B") ("S" "\e$B#S\e(B")
+("T" "\e$B#T\e(B") ("U" "\e$B#U\e(B") ("V" "\e$B#V\e(B") ("W" "\e$B#W\e(B")
+("X" "\e$B#X\e(B") ("Y" "\e$B#Y\e(B") ("Z" "\e$B#Z\e(B") ("[" "\e$B!N\e(B")
+("\\" "\e$B!o\e(B") ("]" "\e$B!O\e(B") ("^" "\e$B!0\e(B") ("_" "\e$B!2\e(B")
+("`" "\e$B!F\e(B") ("a" "\e$B#a\e(B") ("b" "\e$B#b\e(B") ("c" "\e$B#c\e(B")
+("d" "\e$B#d\e(B") ("e" "\e$B#e\e(B") ("f" "\e$B#f\e(B") ("g" "\e$B#g\e(B")
+("h" "\e$B#h\e(B") ("i" "\e$B#i\e(B") ("j" "\e$B#j\e(B") ("k" "\e$B#k\e(B")
+("l" "\e$B#l\e(B") ("m" "\e$B#m\e(B") ("n" "\e$B#n\e(B") ("o" "\e$B#o\e(B")
+("p" "\e$B#p\e(B") ("q" "\e$B#q\e(B") ("r" "\e$B#r\e(B") ("s" "\e$B#s\e(B")
+("t" "\e$B#t\e(B") ("u" "\e$B#u\e(B") ("v" "\e$B#v\e(B") ("w" "\e$B#w\e(B")
+("x" "\e$B#x\e(B") ("y" "\e$B#y\e(B") ("z" "\e$B#z\e(B") ("{" "\e$B!P\e(B")
+("|" "\e$B!C\e(B") ("}" "\e$B!Q\e(B") ("~" "\e$B!A\e(B")
+
+("qq" quail-japanese-switch-package)
+("qh" quail-japanese-switch-package)
+)
+
+(defun quail-japanese-hankaku-update-translation (control-flag)
+  (setq control-flag
+       (quail-japanese-update-translation control-flag))
+  (if (or (and (stringp quail-current-str)
+              (> (length quail-current-str) 0))
+         (integerp quail-current-str))
+      (setq quail-current-str (japanese-hankaku quail-current-str)))
+  control-flag)
+
+(quail-define-package
+ "japanese-hankaku-kana"
+ "Japanese" "\e(I1\e(B"
+ nil
+ "Japanese hankaku katakana input method by Roman transliteration.
+---- Special key bindings ----
+qq:    toggle between this input method and the input method `japanese-ascii'.
+"
+ nil t t nil nil nil nil nil
+ 'quail-japanese-hankaku-update-translation)
+
+(dolist (elt quail-japanese-transliteration-rules)
+  (quail-defrule (car elt)
+                (let ((trans (nth 1 elt)))
+                  (when (or (stringp trans) (vectorp trans))
+                    (let ((s (japanese-hankaku (if (stringp trans)
+                                                   trans
+                                                 (aref trans 0)))))
+                      ;; If the result of the conversion is a string
+                      ;; containing more than one character, make the
+                      ;; result a vector, so that quail-defrule
+                      ;; recognizes the whole string is the
+                      ;; translation, instead of interpreting
+                      ;; individual characters as alternative
+                      ;; translations.
+                      (if (and (stringp s) (> (length s) 1))
+                          (setq trans (vector s))
+                        (setq trans s))))
+                  trans)))
+
+(quail-define-package
+ "japanese-hiragana" "Japanese" "\e$B$"\e(B"
+ nil
+ "Japanese hiragana input method by Roman transliteration."
+ nil t t nil nil nil nil nil
+ 'quail-japanese-update-translation)
+
+;; Use the same map as that of `japanese'.
+(setcar (cdr (cdr quail-current-package))
+       (nth 2 (assoc "japanese" quail-package-alist)))
+
+;; Update Quail translation region while converting Hiragana to Katakana.
+(defun quail-japanese-katakana-update-translation (control-flag)
+  (setq control-flag
+       (quail-japanese-update-translation control-flag))
+  (if (or (and (stringp quail-current-str)
+              (> (length quail-current-str) 0))
+         (integerp quail-current-str))
+      (setq quail-current-str (japanese-katakana quail-current-str)))
+  control-flag)
+
+(quail-define-package
+ "japanese-katakana" "Japanese" "\e$B%"\e(B"
+ nil
+ "Japanese katakana input method by Roman transliteration."
+ nil t t nil nil nil nil nil
+ 'quail-japanese-katakana-update-translation)
+
+(dolist (elt quail-japanese-transliteration-rules)
+  (quail-defrule (car elt)
+                (let ((trans (nth 1 elt)))
+                  (cond ((stringp trans)
+                         (japanese-katakana trans))
+                        ((vectorp trans)
+                         (vector (japanese-katakana (aref trans 0))))
+                        (t trans)))))
+
+;; arch-tag: 47e0bfd4-6ecc-4d01-89a8-d687c5e01ff7
+;;; japanese.el ends here