Mercurial > hg > xemacs-beta
view lisp/mule/korea-util.el @ 4897:91a023144e72
fix longstanding search bug involving searching for Control-1 chars
-------------------- ChangeLog entries follow: --------------------
src/ChangeLog addition:
2010-01-29 Ben Wing <ben@xemacs.org>
* search.c (boyer_moore): Fix longstanding bug involving
searching for Control-1 chars; code was trying to directly
extract the last byte in the textual representation of a char
from an Ichar (and doing it in a buggy fashion) rather than
just converting the Ichar to text and looking at the last byte.
tests/ChangeLog addition:
2010-01-29 Ben Wing <ben@xemacs.org>
* automated/search-tests.el:
New file.
* automated/search-tests.el:
* automated/case-tests.el:
* automated/case-tests.el (pristine-case-table): Removed.
* automated/case-tests.el (uni-mappings):
* automated/lisp-tests.el:
* automated/regexp-tests.el:
Extract some search-related code from case-tests and regexp-tests
and move to search-tests. Move some regexp-related code from
lisp-tests to regexp-tests.
Write a comment trying to express the proper division of labor
between case-tests, search-tests and regexp-tests.
Add a new test for the Control-1 search bug.
Fix a buggy test in the Unicode torture-test section of case-tests.el.
author | Ben Wing <ben@xemacs.org> |
---|---|
date | Fri, 29 Jan 2010 20:57:42 -0600 |
parents | 026c5bf9c134 |
children | 308d34e9f07d |
line wrap: on
line source
;;; korea-util.el --- utilities for Korean -*- coding: iso-2022-7bit; -*- ;; Copyright (C) 1997 Free Software Foundation, Inc. ;; Keywords: mule, multilingual, Korean ;; This file is part of XEmacs. ;; XEmacs 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. ;; XEmacs 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 XEmacs; see the file COPYING. If not, write to the Free ;; Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA ;; 02111-1307, USA. ;;; Synched up with: Emacs 21.1 (language/korea-util.el). ;;; Commentary: ;;; Code: (globally-declare-boundp '(input-method-function isearch-input-method-function isearch-input-method-local-p)) ;;;###autoload (defvar default-korean-keyboard (if (string-match "3" (or (getenv "HANGUL_KEYBOARD_TYPE") "")) "3" "") "*The kind of Korean keyboard for Korean input method. \"\" for 2, \"3\" for 3.") ;; functions useful for Korean text input (defun toggle-korean-input-method () "Turn on or off a Korean text input method for the current buffer." (interactive) (if current-input-method (inactivate-input-method) (activate-input-method (concat "korean-hangul" default-korean-keyboard)))) (defun quail-hangul-switch-symbol-ksc (&rest ignore) "Swith to/from Korean symbol package." (interactive "i") (and current-input-method (if (string-equal current-input-method "korean-symbol") (activate-input-method (concat "korean-hangul" default-korean-keyboard)) (activate-input-method "korean-symbol")))) (defun quail-hangul-switch-hanja (&rest ignore) "Swith to/from Korean hanja package." (interactive "i") (and current-input-method (if (string-match "korean-hanja" current-input-method) (activate-input-method (concat "korean-hangul" default-korean-keyboard)) (activate-input-method (concat "korean-hanja" default-korean-keyboard))))) ;; The following three commands are set in isearch-mode-map. (defun isearch-toggle-korean-input-method () (interactive) (let ((overriding-terminal-local-map nil)) (toggle-korean-input-method)) (setq isearch-input-method-function input-method-function isearch-input-method-local-p t) (setq input-method-function nil) (isearch-update)) (defun isearch-hangul-switch-symbol-ksc () (interactive) (let ((overriding-terminal-local-map nil)) (quail-hangul-switch-symbol-ksc)) (setq isearch-input-method-function input-method-function isearch-input-method-local-p t) (setq input-method-function nil) (isearch-update)) (defun isearch-hangul-switch-hanja () (interactive) (let ((overriding-terminal-local-map nil)) (quail-hangul-switch-hanja)) (setq isearch-input-method-function input-method-function isearch-input-method-local-p t) (setq input-method-function nil) (isearch-update)) ;; Information for setting and exiting Korean environment. (defvar korean-key-bindings `((global [?\S- ] toggle-korean-input-method nil) (global [C-f9] quail-hangul-switch-symbol-ksc nil) (global [f9] quail-hangul-switch-hanja nil) (,isearch-mode-map [?\S- ] isearch-toggle-korean-input-method nil) (,isearch-mode-map [C-f9] isearch-hangul-switch-symbol-ksc nil) (,isearch-mode-map [f9] isearch-hangul-switch-hanja nil))) ;;;###autoload (defun setup-korean-environment-internal () (let ((key-bindings korean-key-bindings)) (while key-bindings (let* ((this (car key-bindings)) (key (nth 1 this)) (new-def (nth 2 this)) old-def) (if (eq (car this) 'global) (progn (setq old-def (global-key-binding key)) (global-set-key key new-def)) (setq old-def (lookup-key (car this) key)) (define-key (car this) key new-def)) (setcar (nthcdr 3 this) old-def)) (setq key-bindings (cdr key-bindings))))) (defun exit-korean-environment () "Exit Korean language environment." (let ((key-bindings korean-key-bindings)) (while key-bindings (let* ((this (car key-bindings)) (key (nth 1 this)) (new-def (nth 2 this)) (old-def (nth 3 this))) (if (eq (car this) 'global) (if (eq (global-key-binding key) new-def) (global-set-key key old-def)) (if (eq (lookup-key (car this) key) new-def) (define-key (car this) key old-def)))) (setq key-bindings (cdr key-bindings))))) ;; (provide 'korea-util) ;;; korea-util.el ends here