Mercurial > emacs
view lisp/x-menu.el @ 29005:b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
CODING_FINISH_INSUFFICIENT_SRC if there's not enough source.
(ONE_MORE_CHAR, EMIT_CHAR, EMIT_ONE_BYTE, EMIT_TWO_BYTE,
EMIT_BYTES): New macros.
(THREE_MORE_BYTES, DECODE_CHARACTER_ASCII,
DECODE_CHARACTER_DIMENSION1, DECODE_CHARACTER_DIMENSION2): These
macros deleted.
(CHECK_CODE_RANGE_A0_FF): This macro deleted.
(detect_coding_emacs_mule): Use UNIBYTE_STR_AS_MULTIBYTE_P to
check the validity of multibyte sequence.
(decode_coding_emacs_mule): New function.
(encode_coding_emacs_mule): New macro.
(detect_coding_iso2022): Use ONE_MORE_BYTE to fetch a byte from
the source.
(DECODE_ISO_CHARACTER): Just return a character code.
(DECODE_COMPOSITION_START): Set coding->result instead of result.
(decode_coding_iso2022, decode_coding_sjis_big5, decode_eol): Use
EMIT_CHAR to produced decoded characters. Exit the loop only by
macros ONE_MORE_BYTE or EMIT_CHAR. Don't handle the case of last
block here.
(ENCODE_ISO_CHARACTER): Don't translate character here. Produce
only position codes for an invalid character.
(encode_designation_at_bol): Return new destination pointer. 5th
arg DSTP is changed to DST.
(encode_coding_iso2022, decode_coding_sjis_big5): Get a character
from the source by ONE_MORE_CHAR. Don't handle the case of last
block here.
(DECODE_SJIS_BIG5_CHARACTER, ENCODE_SJIS_BIG5_CHARACTER): These
macros deleted.
(detect_coding_sjis, detect_coding_big5, detect_coding_utf_8,
detect_coding_utf_16, detect_coding_ccl): Use ONE_MORE_BYTE and
TWO_MORE_BYTES to fetch a byte from the source.
(encode_eol): Pay attention to coding->src_multibyte.
(detect_coding, detect_eol): Preserve members src_multibyte and
dst_multibyte.
(DECODING_BUFFER_MAG): Return 2 even for coding_type_raw_text.
(encoding_buffer_size): Set magnification to 3 for all coding
systems that require encoding.
(ccl_coding_driver): For decoding, be sure that the result is
valid multibyte sequence.
(decode_coding): Initialize coding->errors and coding->result.
For emacs-mule, call decode_coding_emacs_mule. For no-conversion
and raw-text, always call decode_eol. Handle the case of last
block here. If not coding->dst_multibyte, convert the resulting
sequence to unibyte.
(encode_coding): Initialize coding->errors and coding->result.
For emacs-mule, call encode_coding_emacs_mule. For no-conversion
and raw-text, always call encode_eol. Handle the case of last
block here.
(shrink_decoding_region, shrink_encoding_region): Detect cases
that we can't skip data more rigidly.
(code_convert_region): Setup src_multibyte and dst_multibyte
members of coding. For decoding, if the buffer is multibyte,
convert the source sequence to unibyte in advance. For encoding,
if the buffer is multibyte, convert the resulting sequence to
multibyte afterward.
(run_pre_post_conversion_on_str): New function.
(code_convert_string): Deleted and divided into the following two.
(decode_coding_string, encode_coding_string): New functions.
(code_convert_string1, code_convert_string_norecord): Call one of
above.
(Fdecode_sjis_char, Fdecode_big5_char): Use MAKE_CHAR instead of
MAKE_NON_ASCII_CHAR.
(Fset_terminal_coding_system_internal,
Fset_safe_terminal_coding_system_internal): Setup src_multibyte
and dst_multibyte members.
(init_coding_once): Initialize iso_code_class with new enum
ISO_control_0 and ISO_control_1.
author | Kenichi Handa <handa@m17n.org> |
---|---|
date | Fri, 19 May 2000 23:54:56 +0000 |
parents | 11218164bc54 |
children | 67b464da13ec |
line wrap: on
line source
;;; x-menu.el --- menu support for X ;; Copyright (C) 1986 Free Software Foundation, Inc. ;; 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: (defun x-menu-mode () "Major mode for creating permanent menus for use with X. These menus are implemented entirely in Lisp; popup menus, implemented with x-popup-menu, are implemented using XMenu primitives." (make-local-variable 'x-menu-items-per-line) (make-local-variable 'x-menu-item-width) (make-local-variable 'x-menu-items-alist) (make-local-variable 'x-process-mouse-hook) (make-local-variable 'x-menu-assoc-buffer) (setq buffer-read-only t) (setq truncate-lines t) (setq x-process-mouse-hook 'x-menu-pick-entry) (setq mode-line-buffer-identification '("MENU: %32b"))) (defvar x-menu-max-width 0) (defvar x-menu-items-per-line 0) (defvar x-menu-item-width 0) (defvar x-menu-items-alist nil) (defvar x-menu-assoc-buffer nil) (defvar x-menu-item-spacing 1 "*Minimum horizontal spacing between objects in a permanent X menu.") (defun x-menu-create-menu (name) "Create a permanent X menu. Returns an item which should be used as a menu object whenever referring to the menu." (let ((old (current-buffer)) (buf (get-buffer-create name))) (set-buffer buf) (x-menu-mode) (setq x-menu-assoc-buffer old) (set-buffer old) buf)) (defun x-menu-change-associated-buffer (menu buffer) "Change associated buffer of MENU to BUFFER. BUFFER should be a buffer object." (let ((old (current-buffer))) (set-buffer menu) (setq x-menu-assoc-buffer buffer) (set-buffer old))) (defun x-menu-add-item (menu item binding) "Add to MENU an item with name ITEM, associated with BINDING. Following a sequence of calls to x-menu-add-item, a call to x-menu-compute should be performed before the menu will be made available to the user. BINDING should be a function of one argument, which is the numerical button/key code as defined in x-menu.el." (let ((old (current-buffer)) elt) (set-buffer menu) (if (setq elt (assoc item x-menu-items-alist)) (rplacd elt binding) (setq x-menu-items-alist (append x-menu-items-alist (list (cons item binding))))) (set-buffer old) item)) (defun x-menu-delete-item (menu item) "Delete from MENU the item named ITEM. Call `x-menu-compute' before making the menu available to the user." (let ((old (current-buffer)) elt) (set-buffer menu) (if (setq elt (assoc item x-menu-items-alist)) (rplaca elt nil)) (set-buffer old) item)) (defun x-menu-activate (menu) "Compute all necessary parameters for MENU. This must be called whenever a menu is modified before it is made available to the user. This also creates the menu itself." (let ((buf (current-buffer))) (pop-to-buffer menu) (let (buffer-read-only) (setq x-menu-max-width (1- (frame-width))) (setq x-menu-item-width 0) (let (items-head (items-tail x-menu-items-alist)) (while items-tail (if (car (car items-tail)) (progn (setq items-head (cons (car items-tail) items-head)) (setq x-menu-item-width (max x-menu-item-width (length (car (car items-tail))))))) (setq items-tail (cdr items-tail))) (setq x-menu-items-alist (reverse items-head))) (setq x-menu-item-width (+ x-menu-item-spacing x-menu-item-width)) (setq x-menu-items-per-line (max 1 (/ x-menu-max-width x-menu-item-width))) (erase-buffer) (let ((items-head x-menu-items-alist)) (while items-head (let ((items 0)) (while (and items-head (<= (setq items (1+ items)) x-menu-items-per-line)) (insert (format (concat "%" (int-to-string x-menu-item-width) "s") (car (car items-head)))) (setq items-head (cdr items-head)))) (insert ?\n))) (shrink-window (max 0 (- (window-height) (1+ (count-lines (point-min) (point-max)))))) (goto-char (point-min))) (pop-to-buffer buf))) (defun x-menu-pick-entry (position event) "Internal function for dispatching on mouse/menu events" (let* ((x (min (1- x-menu-items-per-line) (/ (current-column) x-menu-item-width))) (y (- (count-lines (point-min) (point)) (if (zerop (current-column)) 0 1))) (item (+ x (* y x-menu-items-per-line))) (litem (cdr (nth item x-menu-items-alist)))) (and litem (funcall litem event))) (pop-to-buffer x-menu-assoc-buffer)) (provide 'x-menu) ;;; x-menu.el ends here