;;; skk-foreword.el --- 前書き ;; Copyright (C) 1997, 1998, 1999 Mikio Nakajima ;; Author: Mikio Nakajima ;; Maintainer: Hideki Sakurada ;; Murata Shuuichirou ;; Mikio Nakajima ;; Version: $Id: skk-foreword.el,v 1.5 2002-04-28 07:12:27 youngs Exp $ ;; Keywords: japanese ;; Last Modified: $Date: 2002-04-28 07:12:27 $ ;; This file is not part of SKK yet. ;; SKK 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 versions 2, or (at your option) ;; any later version. ;; SKK 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 SKK, see the file COPYING. If not, write to the Free ;; Software Foundation Inc., 59 Temple Place - Suite 330, Boston, ;; MA 02111-1307, USA. ;;; Commentary: ;; このファイルは、ユーザー変数の宣言自体に使用するマクロ、skk-*.el で ;; 使用するマクロなど、変数の宣言以前、skk-*.el の最初に定義しておかな ;; ければならないものをまとめたものです。ユーザー変数の定義の前に、ご ;; ちゃごちゃとユーザーに興味がないものが並んでいたのでは、ユーザーフ ;; レンドリーではないと考えるからです。 ;; ;;; Code: (cond ((or (and (boundp 'epoch::version) epoch::version) (string< (substring emacs-version 0 2) "18") ) (error "THIS SKK requires Emacs 19 or later") ) ((not (featurep 'mule)) (error "THIS SKK requires MULE features") )) (eval-when-compile (defvar skk-abbrev-cursor-color) (defvar skk-abbrev-mode) (defvar skk-abbrev-mode-string) (defvar skk-current-rule-tree) (defvar skk-default-cursor-color) (defvar skk-downcase-alist) (defvar skk-echo) (defvar skk-hankaku-alist) (defvar skk-henkan-count) (defvar skk-henkan-list) (defvar skk-hiragana-cursor-color) (defvar skk-hiragana-mode-string) (defvar skk-input-mode-string) (defvar skk-j-mode) (defvar skk-jisx0208-latin-cursor-color) (defvar skk-jisx0208-latin-mode) (defvar skk-jisx0208-latin-mode-string) (defvar skk-kana-cleanup-command-list) (defvar skk-kana-input-search-function) (defvar skk-kana-start-point) (defvar skk-katakana) (defvar skk-katakana-cursor-color) (defvar skk-katakana-mode-string) (defvar skk-last-henkan-data) (defvar skk-latin-cursor-color) (defvar skk-latin-mode) (defvar skk-latin-mode-string) (defvar skk-look-completion-words) (defvar skk-mode) (defvar skk-prefix) (defvar skk-previous-point) (defvar skk-use-numeric-conversion) ) (require 'advice) (require 'easymenu) ;; APEL 9.22 or later required. (eval-when-compile (require 'static)) (require 'poe) (require 'poem) ; requires pces. (require 'pcustom) (require 'alist) ;; Elib 1.0 is required. (require 'queue-m) ;;;###autoload (eval-and-compile (defconst skk-emacs-type (cond ((featurep 'xemacs) 'xemacs) ((and (boundp 'mule-version) (string< "4.0" mule-version) 'mule4 )) ((and (boundp 'mule-version) (string< "3.0" mule-version) 'mule3 )) ((and (boundp 'mule-version) (string< "2.0" mule-version) 'mule2 ))))) ;; necessary macro and functions to be declared before user variable declarations. ;;;; macros ;; Why I use non-intern temporary variable in the macro --- see comment in ;; save-match-data of subr.el of GNU Emacs. And should we use the same manner ;; in the save-current-buffer, with-temp-buffer and with-temp-file macro ;; definition? (defmacro skk-save-point (&rest body) (` (let ((skk-save-point (point-marker))) (unwind-protect (progn (,@ body)) (goto-char skk-save-point) (skk-set-marker skk-save-point nil) )))) (defmacro skk-message (japanese english &rest arg) ;; skk-japanese-message-and-error が non-nil だったら JAPANESE を nil であれ ;; ば ENGLISH をエコーエリアに表示する。 ;; ARG は message 関数の第2引数以降の引数として渡される。 (append (list 'message (list 'if 'skk-japanese-message-and-error japanese english )) arg )) (defmacro skk-error (japanese english &rest arg) ;; skk-japanese-message-and-error が non-nil だったら JAPANESE を nil であれ ;; ば ENGLISH をエコーエリアに表示し、エラーを発生させる。 ;; ARG は error 関数の第2引数以降の引数として渡される。 (append (list 'error (list 'if 'skk-japanese-message-and-error japanese english )) arg )) (defmacro skk-yes-or-no-p (japanese english) ;; skk-japanese-message-and-error が non-nil であれば、japanese を nil であ ;; れば english をプロンプトとして yes-or-no-p を実行する。 ;; yes-or-no-p の引数のプロンプトが複雑に入れ込んでいる場合はこのマクロを使 ;; うよりオリジナルの yes-or-no-p を使用した方がコードが複雑にならない場合が ;; ある。 (list 'yes-or-no-p (list 'if 'skk-japanese-message-and-error japanese english ))) (defmacro skk-y-or-n-p (japanese english) ;; skk-japanese-message-and-error が non-nil であれば、japanese を nil であ ;; れば english をプロンプトとして y-or-n-p を実行する。 (list 'y-or-n-p (list 'if 'skk-japanese-message-and-error japanese english ))) (defmacro skk-set-marker (marker position &optional buffer) ;; バッファローカル値である skk-henkan-start-point, skk-henkan-end-point, ;; skk-kana-start-point, あるいは skk-okurigana-start-point が nil だったら、 ;; 新規マーカーを作って代入する。 (list 'progn (list 'if (list 'not marker) (list 'setq marker (list 'make-marker)) ) (list 'set-marker marker position buffer) )) ;; From viper-util.el. Welcome! (defmacro skk-deflocalvar (var default-value &optional documentation) (` (progn (defvar (, var) (, default-value) (, (format "%s\n\(buffer local\)" documentation))) (make-variable-buffer-local '(, var)) ))) (defmacro skk-with-point-move (&rest form) ;; ポイントを移動するがフックを実行してほしくない場合に使う。 (` (unwind-protect (progn (,@ form)) (setq skk-previous-point (point)) ))) (defmacro skk-face-on (object start end face &optional priority) (static-cond ((eq skk-emacs-type 'xemacs) (` (let ((inhibit-quit t)) (if (not (extentp (, object))) (progn (setq (, object) (make-extent (, start) (, end))) (if (not (, priority)) (set-extent-face (, object) (, face)) (set-extent-properties (, object) (list 'face (, face) 'priority (, priority)) ))) (set-extent-endpoints (, object) (, start) (, end)) )))) (t (` (let ((inhibit-quit t)) (if (not (overlayp (, object))) (progn (setq (, object) (make-overlay (, start) (, end))) (and (, priority) (overlay-put (, object) 'priority (, priority))) (overlay-put (, object) 'face (, face)) ) (move-overlay (, object) (, start) (, end)) )))))) (put 'skk-deflocalvar 'lisp-indent-function 'defun) ;;;; inline functions (defsubst skk-file-exists-and-writable-p (file) (and (setq file (expand-file-name file)) (file-exists-p file) (file-writable-p file) )) (defsubst skk-lower-case-p (char) ;; CHAR が小文字のアルファベットであれば、t を返す。 (and (<= ?a char) (>= ?z char) )) (defsubst skk-downcase (char) (or (cdr (assq char skk-downcase-alist)) (downcase char)) ) (defsubst skk-mode-off () (setq skk-mode nil skk-abbrev-mode nil skk-latin-mode nil skk-j-mode nil skk-jisx0208-latin-mode nil ;; j's sub mode. skk-katakana nil ) ;; initialize (setq skk-input-mode-string skk-hiragana-mode-string) (force-mode-line-update) (remove-hook 'pre-command-hook 'skk-pre-command 'local) ) (defsubst skk-j-mode-on (&optional katakana) (setq skk-mode t skk-abbrev-mode nil skk-latin-mode nil skk-j-mode t skk-jisx0208-latin-mode nil ;; j's sub mode. skk-katakana katakana ) ;; mode line (setq skk-input-mode-string (if katakana skk-katakana-mode-string skk-hiragana-mode-string )) (force-mode-line-update) ) (defsubst skk-latin-mode-on () (setq skk-mode t skk-abbrev-mode nil skk-latin-mode t skk-j-mode nil skk-jisx0208-latin-mode nil ;; j's sub mode. skk-katakana nil skk-input-mode-string skk-latin-mode-string ) (force-mode-line-update) ) (defsubst skk-jisx0208-latin-mode-on () (setq skk-mode t skk-abbrev-mode nil skk-latin-mode nil skk-j-mode nil skk-jisx0208-latin-mode t ;; j's sub mode. skk-katakana nil skk-input-mode-string skk-jisx0208-latin-mode-string ) (force-mode-line-update) ) (defsubst skk-abbrev-mode-on () (setq skk-mode t skk-abbrev-mode t skk-latin-mode nil skk-j-mode nil skk-jisx0208-latin-mode nil ;; j's sub mode. skk-katakana nil skk-input-mode-string skk-abbrev-mode-string ) (force-mode-line-update) ) (defsubst skk-in-minibuffer-p () ;; カレントバッファがミニバッファかどうかをチェックする。 (window-minibuffer-p (selected-window)) ) (defsubst skk-insert-prefix (&optional char) ;; skk-echo が non-nil であればカレントバッファに skk-prefix を挿入する。 (and skk-echo ;; skk-prefix の挿入をアンドゥの対象としない。挿入したプレフィックスは、 ;; かな文字を挿入する前に全て消去するので、その間、buffer-undo-list を ;; t にしてアンドゥ情報を蓄えなくとも問題がない。 (let ((buffer-undo-list t)) (insert-and-inherit (or char skk-prefix)) ))) (defsubst skk-erase-prefix (&optional clean) ;; skk-echo が non-nil であればカレントバッファに挿入された skk-prefix を消 ;; す。オプショナル引数の CLEAN が指定されると、変数としての skk-prefix を ;; null 文字に、skk-current-rule-tree を nil 初期化する。 ;; ;; かな文字の入力がまだ完成していない場合にこの関数が呼ばれたときなどは、バッ ;; ファに挿入されている skk-prefix は削除したいが、変数としての skk-prefix は ;; null 文字にしたくない。 (and skk-echo skk-kana-start-point (not (string= skk-prefix "")) ; fail safe. ;; skk-prefix の消去をアンドゥの対象としない。 (let ((buffer-undo-list t) (start (marker-position skk-kana-start-point)) ) (and start (condition-case nil (delete-region start (+ start (length skk-prefix))) (error (skk-set-marker skk-kana-start-point nil) (setq skk-prefix "" skk-current-rule-tree nil )))))) (and clean (setq skk-prefix "" skk-current-rule-tree nil ))) ; fail safe (defsubst skk-string<= (str1 str2) ;; STR1 と STR2 とを比較して、string< か string= であれば、t を返す。 (or (string< str1 str2) (string= str1 str2)) ) (defsubst skk-do-auto-fill () ;; auto-fill-function に値が代入されておれば、do-auto-fill をコールする。 (and auto-fill-function (funcall auto-fill-function)) ) ;;;; from dabbrev.el. Welcome! ;; 判定間違いを犯す場合あり。要改良。 (defsubst skk-minibuffer-origin () (nth 1 (buffer-list)) ) (defsubst skk-current-insert-mode () (cond (skk-abbrev-mode 'abbrev) (skk-latin-mode 'latin) (skk-jisx0208-latin-mode 'jisx0208-latin) (skk-katakana 'katakana) (skk-j-mode 'hiragana) )) (defsubst skk-numeric-p () (and skk-use-numeric-conversion (require 'skk-num) skk-num-list) ) (defsubst skk-substring-head-character (string) (char-to-string (string-to-char string)) ) (defsubst skk-get-current-candidate-simply (&optional noconv) (if (> 0 skk-henkan-count) (skk-error "候補を取り出すことができません" "Cannot get current candidate" ) ;; (nth -1 '(A B C)) は、A を返すので、負でないかどうかチェックする。 (let ((word (nth skk-henkan-count skk-henkan-list))) (and word (if (and (skk-numeric-p) (consp word)) (if noconv (car word) (cdr word)) word ))))) ;; convert skk-rom-kana-rule-list to skk-rule-tree. ;; The rule tree follows the following syntax: ;; ::= nil | ( . ) ;; ::= ( ) ;; ::= (<ひらがな文字列> . <カタカナ文字列>) | nil ;; ::= <英小文字> ;; ::= <英小文字文字列> | nil ;; ツリーにアクセスするためのインターフェース (defsubst skk-make-rule-tree (char prefix nextstate kana branch-list) (list char prefix (if (string= nextstate "") nil nextstate) kana branch-list )) (defsubst skk-get-char (tree) (car tree) ) (defsubst skk-set-char (tree char) (setcar tree char) ) (defsubst skk-set-prefix (tree prefix) (setcar (nthcdr 1 tree) prefix) ) (defsubst skk-get-prefix (tree) (nth 1 tree) ) (defsubst skk-get-nextstate (tree) (nth 2 tree) ) (defsubst skk-set-nextstate (tree nextstate) (if (string= nextstate "") (setq nextstate nil)) (setcar (nthcdr 2 tree) nextstate) ) (defsubst skk-get-kana (tree) (nth 3 tree) ) (defsubst skk-set-kana (tree kana) (setcar (nthcdr 3 tree) kana) ) (defsubst skk-get-branch-list (tree) (nth 4 tree) ) (defsubst skk-set-branch-list (tree branch-list) (setcar (nthcdr 4 tree) branch-list) ) ;; tree procedure for skk-kana-input. (defsubst skk-add-branch (tree branch) (skk-set-branch-list tree (cons branch (skk-get-branch-list tree))) ) (defsubst skk-select-branch (tree char) (assq char (skk-get-branch-list tree)) ) (defsubst skk-kana-cleanup (&optional force) (let ((data (or (and skk-current-rule-tree (null (skk-get-nextstate skk-current-rule-tree)) (skk-get-kana skk-current-rule-tree) ) (and skk-kana-input-search-function (car (funcall skk-kana-input-search-function)) ))) kana ) (if (or force data) (progn (skk-erase-prefix 'clean) (setq kana (if (functionp data) (funcall data nil) data)) (if (consp kana) (setq kana (if skk-katakana (car kana) (cdr kana))) ) (if (stringp kana) (skk-insert-str kana)) (skk-set-marker skk-kana-start-point nil) t )))) (defsubst skk-pre-command () (and (memq last-command '(skk-insert skk-previous-candidate)) (null (memq this-command skk-kana-cleanup-command-list)) (skk-kana-cleanup t) )) (defsubst skk-make-raw-arg (arg) (cond ((= arg 1) nil) ((= arg -1) '-) ((numberp arg) (list arg)) )) (defsubst skk-unread-event (event) ;; Unread single EVENT. (setq unread-command-events (nconc unread-command-events (list event))) ) (defsubst skk-after-point-move () (and (or (not skk-previous-point) (not (= skk-previous-point (point)))) (skk-get-prefix skk-current-rule-tree) (skk-with-point-move (skk-erase-prefix 'clean)) )) (defsubst skk-get-last-henkan-data (key) (cdr (assq key skk-last-henkan-data)) ) (defsubst skk-put-last-henkan-data (key val) (setq skk-last-henkan-data (put-alist key val skk-last-henkan-data)) ) (defun skk-terminal-face-p () (and (not window-system) ;;; XEmacs does not have this function... (fboundp 'frame-face-alist) ; 変数名みたいな関数だな...。 (fboundp 'selected-frame) )) ;;;; aliases ;; for backward compatibility. (define-obsolete-function-alias 'skk-zenkaku-mode 'skk-jisx0208-latin-mode) (define-obsolete-function-alias 'skk-zenkaku-mode-on 'skk-jisx0208-latin-mode-on) (define-obsolete-function-alias 'skk-zenkaku-insert 'skk-jisx0208-latin-insert) (define-obsolete-function-alias 'skk-zenkaku-region 'skk-jisx0208-latin-region) (define-obsolete-function-alias 'skk-zenkaku-henkan 'skk-jisx0208-latin-henkan) (define-obsolete-function-alias 'skk-ascii-mode-on 'skk-latin-mode-on) (define-obsolete-function-alias 'skk-ascii-mode 'skk-latin-mode) (define-obsolete-function-alias 'skk-ascii-region 'skk-latin-region) (define-obsolete-function-alias 'skk-ascii-henkan 'skk-latin-henkan) (define-obsolete-function-alias 'skk-convert-ad-to-gengo 'skk-ad-to-gengo) (define-obsolete-function-alias 'skk-convert-gengo-to-ad 'skk-gengo-to-ad) (define-obsolete-function-alias 'skk-isearch-forward 'isearch-forward) (define-obsolete-function-alias 'skk-isearch-forward-regexp 'isearch-forward-regexp) (define-obsolete-function-alias 'skk-isearch-backward 'isearch-backward) (define-obsolete-function-alias 'skk-isearch-backward-regexp 'isearch-backward-regexp) (defconst skk-background-mode ;; from font-lock-make-faces of font-lock.el Welcome! (cond ((eq skk-emacs-type 'xemacs) (if (< (apply '+ (color-rgb-components (face-property 'default 'background) )) (/ (apply '+ (color-rgb-components (make-color-specifier "white"))) 3)) 'dark 'light )) ((and window-system (x-display-color-p)) (let ((bg-resource (x-get-resource ".backgroundMode" "BackgroundMode")) params ) (if bg-resource (intern (downcase bg-resource)) (setq params (frame-parameters)) (cond ((cdr (assq 'background-mode params)));; Emacs20.x (Meadow) ((and (eq system-type 'windows-nt);; Mule for Win32 (fboundp 'win32-color-values) ) (< (apply '+ (win32-color-values (cdr (assq 'background-color params)) )) (/ (apply '+ (win32-color-values "white")) 3) ) 'dark ) ((and (memq system-type '(ms-dos windows-nt)) (fboundp 'x-color-values) ) (if (string-match "light" (cdr (assq 'background-color params)) ) 'light 'dark )) ((< (apply '+ (x-color-values (cdr (assq 'background-color params)) )) (/ (apply '+ (x-color-values "white")) 3) ) 'dark ) (t 'light) )))) (t 'mono) )) ;;;; version specific matter. ;;; inline functions. (defsubst skk-str-length (str) (static-cond ((memq skk-emacs-type '(xemacs mule4)) (length str) ) ((eq skk-emacs-type 'mule3) (length (string-to-vector str)) ) ((eq skk-emacs-type 'mule2) (length (string-to-list str)) ))) (defsubst skk-substring (str pos1 pos2) (static-cond ((memq skk-emacs-type '(xemacs mule4)) (substring str pos1 pos2) ) ((eq skk-emacs-type 'mule3) (if (< pos1 0) (setq pos1 (+ (skk-str-length str) pos1)) ) (if (< pos2 0) (setq pos2 (+ (skk-str-length str) pos2)) ) (if (>= pos1 pos2) "" (let ((sl (nthcdr pos1 (string-to-list str)))) (setcdr (nthcdr (- pos2 pos1 1) sl) nil) (concat sl) ))) ((eq skk-emacs-type 'mule2) (if (< pos1 0) (setq pos1 (+ (skk-str-length str) pos1)) ) (if (< pos2 0) (setq pos2 (+ (skk-str-length str) pos2)) ) (if (>= pos1 pos2) "" (let ((sl (nthcdr pos1 (string-to-list str)))) (setcdr (nthcdr (- pos2 pos1 1) sl) nil) (mapconcat 'char-to-string sl "") ))))) ;; no argument use only in SKK. (defsubst skk-read-event () (static-cond ((eq skk-emacs-type 'xemacs) (next-command-event) ) (t (read-event)) )) (defsubst skk-char-to-string (char) (static-cond ((eq skk-emacs-type 'xemacs) (char-to-string char) ) ((string< "20" emacs-version) (condition-case nil (char-to-string char) (error)) ) (t (char-to-string char)) )) (defsubst skk-ascii-char-p (char) ;; CHAR が ascii 文字だったら t を返す。 (static-cond ((memq skk-emacs-type '(xemacs mule4 mule3)) (eq (char-charset char) 'ascii) ) ((eq skk-emacs-type 'mule2) (= (char-leading-char char) 0) ))) (defsubst skk-str-ref (str pos) (static-cond ((memq skk-emacs-type '(xemacs mule4)) (aref str pos) ) ((eq skk-emacs-type 'mule3) (aref (string-to-vector str) pos ) ) ((eq skk-emacs-type 'mule2) (nth pos (string-to-list str)) ))) (defsubst skk-jisx0208-p (char) (static-cond ((memq skk-emacs-type '(xemacs mule4 mule3)) (eq (char-charset char) 'japanese-jisx0208) ) ((eq skk-emacs-type 'mule2) (= (char-leading-char char) lc-jp) ))) (defsubst skk-char-octet (ch &optional n) (static-cond ((eq skk-emacs-type 'xemacs) (or (nth (if n (1+ n) 1) (split-char ch)) 0) ) (t (char-octet ch n)) )) ;;; normal functions. ;; tiny function, but called once in skk-kcode.el. So not make it inline. ;; or should I think to move to skk-kcode.el? (defun skk-make-char (charset n1 n2) (static-cond ((eq skk-emacs-type 'xemacs) (make-char charset (logand (lognot 128) n1) (logand (lognot 128) n2)) ) ((memq skk-emacs-type '(mule4 mule3)) (make-char charset n1 n2) ) ((eq skk-emacs-type 'mule2) (make-character charset n1 n2) ))) ;; this one is called once in skk-kcode.el, too. (defsubst skk-charsetp (object) (static-cond ((and (eq skk-emacs-type 'xemacs) (fboundp 'charsetp)) (charsetp object) ) ((eq skk-emacs-type 'xemacs) ;; Is there XEmacs that doesn't have `charsetp'? (find-charset object) ) ((memq skk-emacs-type '(mule4 mule3)) (charsetp object) ) ((eq skk-emacs-type 'mule2) (character-set object) ))) (defun skk-jisx0208-to-ascii (string) (static-cond ((memq skk-emacs-type '(xemacs mule4 mule3)) (require 'japan-util) (let ((char (get-char-code-property (string-to-char string) 'ascii) )) (and char (char-to-string char)) )) ((eq skk-emacs-type 'mule2) (let ((char (let* ((ch (string-to-char string)) (ch1 (char-component ch 1)) ) (cond ((eq 161 ch1) ; ?\241 (cdr (assq (char-component ch 2) skk-hankaku-alist)) ) ((eq 163 ch1) ; ?\243 (- (char-component ch 2) 128) ; ?\200 ))))) (and char (char-to-string char)) )))) (defun skk-define-menu-bar-map (map) ;; SKK メニューのトップに出現するコマンドのメニューへの定義を行なう。 (easy-menu-define skk-menu map "Menu used in SKK mode." '("SKK" ("Convert Region and Echo" ("Gyakubiki" ["to Hiragana" skk-gyakubiki-message (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Hiragana, All Candidates" ;; あれれ、lambda 関数は定義できないのか??? 動かないぞ...。 (function (lambda (start end) (interactive "r") (skk-gyakubiki-message start end 'all-candidates) )) (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Katakana" skk-gyakubiki-katakana-message (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Katakana, All Candidates" (function (lambda (start end) (interactive "r") (skk-gyakubiki-katakana-message start end 'all-candidates ) )) (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ) ("Hurigana" ["to Hiragana" skk-hurigana-message (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Hiragana, All Candidates" (function (lambda (start end) (interactive "r") (skk-hurigana-message start end 'all-candidates) )) (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Katakana" skk-hurigana-katakana-message (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Katakana, All Candidates" (function (lambda (start end) (interactive "r") (skk-hurigana-katakana-message start end 'all-candidates) )) (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ) ) ("Convert Region and Replace" ["Ascii" skk-ascii-region (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ("Gyakubiki" ["to Hiragana" skk-gyakubiki-region (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Hiragana, All Candidates" (function (lambda (start end) (interactive "r") (skk-gyakubiki-region start end 'all-candidates) )) (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Katakana" skk-gyakubiki-katakana-region (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Katakana, All Candidates" (function (lambda (start end) (interactive "r") (skk-gyakubiki-katakana-region start end 'all-candidates ) )) (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ) ["Hiragana" skk-hiragana-region (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ("Hurigana" ["to Hiragana" skk-hurigana-region (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Hiragana, All Candidates" (function (lambda (start end) (interactive "r") (skk-hurigana-region start end 'all-candidates) )) (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Katakana" skk-hurigana-katakana-region (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["to Katakana, All Candidates" (function (lambda (start end) (interactive "r") (skk-hurigana-katakana-region start end 'all-candidates) )) (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ) ["Katakana" skk-katakana-region (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["Romaji" skk-romaji-region (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["Zenkaku" skk-jisx0208-latin-region (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ) ["Count Jisyo Candidates" skk-count-jisyo-candidates (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["Save Jisyo" skk-save-jisyo (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["Undo Kakutei" skk-undo-kakutei (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ["Version" skk-version (or (not (boundp 'skktut-problem-count)) (eq skktut-problem-count 0)) ] ))) (provide 'skk-foreword) ;;; Local Variables: ;;; End: ;;; skk-forwords.el ends here