view lisp/mule/vietnamese.el @ 5142:f965e31a35f0

reduce lcrecord headers to 2 words, rename printing_unreadable_object -------------------- ChangeLog entries follow: -------------------- man/ChangeLog addition: 2010-03-13 Ben Wing <ben@xemacs.org> * internals/internals.texi (Working with Lisp Objects): * internals/internals.texi (Writing Macros): * internals/internals.texi (lrecords): More rewriting to correspond with changes from *LRECORD* to *LISP_OBJECT*. modules/ChangeLog addition: 2010-03-13 Ben Wing <ben@xemacs.org> * postgresql/postgresql.c (print_pgconn): * postgresql/postgresql.c (print_pgresult): printing_unreadable_object -> printing_unreadable_object_fmt. 2010-03-13 Ben Wing <ben@xemacs.org> * ldap/eldap.c (print_ldap): printing_unreadable_object -> printing_unreadable_object_fmt. src/ChangeLog addition: 2010-03-13 Ben Wing <ben@xemacs.org> * alloc.c (alloc_sized_lrecord_1): * alloc.c (alloc_sized_lrecord_array): * alloc.c (old_alloc_sized_lcrecord): * alloc.c (disksave_object_finalization_1): * alloc.c (mark_lcrecord_list): * alloc.c (alloc_managed_lcrecord): * alloc.c (free_managed_lcrecord): * alloc.c (tick_lcrecord_stats): * alloc.c (sweep_lcrecords_1): * buffer.c (print_buffer): * buffer.c (DEFVAR_BUFFER_LOCAL_1): * casetab.c: * casetab.c (print_case_table): * console.c (print_console): * console.c (DEFVAR_CONSOLE_LOCAL_1): * data.c (print_weak_list): * data.c (print_weak_box): * data.c (print_ephemeron): * data.c (ephemeron_equal): * database.c (print_database): * database.c (finalize_database): * device-msw.c (sync_printer_with_devmode): * device-msw.c (print_devmode): * device-msw.c (finalize_devmode): * device.c: * device.c (print_device): * elhash.c: * elhash.c (print_hash_table): * eval.c (print_subr): * eval.c (print_multiple_value): * event-stream.c (event_stream_resignal_wakeup): * events.c (clear_event_resource): * events.c (zero_event): * events.c (print_event): * extents.c: * extents.c (print_extent): * file-coding.c (print_coding_system): * font-mgr.c: * font-mgr.c (Ffc_init): * frame.c: * frame.c (print_frame): * gc.c: * gc.c (GC_CHECK_NOT_FREE): * glyphs.c: * glyphs.c (print_image_instance): * glyphs.c (print_glyph): * gui.c (print_gui_item): * gui.c (copy_gui_item): * keymap.c (print_keymap): * keymap.c (MARKED_SLOT): * lisp.h: * lisp.h (struct Lisp_String): * lisp.h (DEFUN): * lisp.h (DEFUN_NORETURN): * lrecord.h: * lrecord.h (NORMAL_LISP_OBJECT_UID): * lrecord.h (struct lrecord_header): * lrecord.h (set_lheader_implementation): * lrecord.h (struct old_lcrecord_header): * lrecord.h (struct free_lcrecord_header): * marker.c (print_marker): * mule-charset.c: * mule-charset.c (print_charset): * objects.c (print_color_instance): * objects.c (print_font_instance): * objects.c (finalize_font_instance): * print.c (print_cons): * print.c (printing_unreadable_object_fmt): * print.c (printing_unreadable_lisp_object): * print.c (external_object_printer): * print.c (internal_object_printer): * print.c (debug_p4): * print.c (ext_print_begin): * process.c (print_process): * rangetab.c (print_range_table): * rangetab.c (range_table_equal): * scrollbar.c (free_scrollbar_instance): * specifier.c (print_specifier): * specifier.c (finalize_specifier): * symbols.c (guts_of_unbound_marker): * symeval.h: * symeval.h (DEFVAR_SYMVAL_FWD): * tooltalk.c: * tooltalk.c (print_tooltalk_message): * tooltalk.c (print_tooltalk_pattern): * ui-gtk.c (ffi_object_printer): * ui-gtk.c (emacs_gtk_object_printer): * ui-gtk.c (emacs_gtk_boxed_printer): * window.c (print_window): * window.c (free_window_mirror): * window.c (debug_print_window): * xemacs.def.in.in: (1) printing_unreadable_object -> printing_unreadable_object_fmt. (2) printing_unreadable_lcrecord -> printing_unreadable_lisp_object and fix up so it no longer requires an lcrecord. These previous changes eliminate most of the remaining places where the terms `lcrecord' and `lrecord' occurred outside of specialized code. (3) Fairly major change: Reduce the number of words in an lcrecord from 3 to 2. The third word consisted of a uid that duplicated the lrecord uid, and a single free bit, which was moved into the lrecord structure. This reduces the size of the `uid' slot from 21 bits to 20 bits. Arguably this isn't enough -- we could easily have more than 1,000,000 or so objects created in a session. The answer is (a) It doesn't really matter if we overflow the uid field because it's only used for debugging, to identify an object uniquely (or pretty much so). (b) If we cared about it overflowing and wanted to reduce this, we could make it so that cons, string, float and certain other frob-block types that never print out the uid simply don't store a uid in them and don't increment the lrecord_uid_counter. (4) In conjunction with (3), create new macro NORMAL_LISP_OBJECT_UID() and use it to abstract out the differences between NEWGC and old-GC in accessing the `uid' value from a "normal Lisp Object pointer". (5) In events.c, use zero_nonsized_lisp_object() in place of custom- written equivalent. In font-mgr.c use external_object_printer() in place of custom-written equivalents.
author Ben Wing <ben@xemacs.org>
date Sat, 13 Mar 2010 05:38:08 -0600 (2010-03-13)
parents 29fb3baea939
children 308d34e9f07d
line wrap: on
line source
;;; vietnamese.el --- Support for Vietnamese -*- coding: iso-2022-7bit; -*-

;; Copyright (C) 1995 Electrotechnical Laboratory, JAPAN.
;; Licensed to the Free Software Foundation.
;; Copyright (C) 1997 MORIOKA Tomohiko
;; Copyright (C) 2002 Ben Wing.

;; Keywords: multilingual, Vietnamese

;; 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.

;;; Commentary:

;; For Vietnamese, the character sets VISCII and VSCII are supported.

;;; Code:

;; Vietnamese VISCII.  VISCII is 1-byte character set which contains
;; more than 96 characters.  Since Emacs can't handle it as one
;; character set, it is divided into two: lower case letters and upper
;; case letters.
(make-charset 'vietnamese-viscii-lower "VISCII1.1 lower-case"
	      '(dimension
		1
		registries ["VISCII1.1"]
		chars 96
		columns 1
		direction l2r
		final ?1
		graphic 1
		short-name "VISCII lower"
		long-name "VISCII lower-case"
		))

(make-charset 'vietnamese-viscii-upper "VISCII1.1 upper-case"
	      '(dimension
		1
		registries ["VISCII1.1"]
		chars 96
		columns 1
		direction l2r
		final ?2
		graphic 1
		short-name "VISCII upper"
		long-name "VISCII upper-case"
		))

(define-category ?v "Vietnamese character.")
(modify-category-entry 'vietnamese-viscii-lower ?v)
(modify-category-entry 'vietnamese-viscii-upper ?v)

(make-coding-system 
 'viscii 'fixed-width "VISCII 1.1 (Vietnamese)"
 '(unicode-map
   ((#x02 ?\u1EB2) ;; CAPITAL LETTER A WITH BREVE AND HOOK ABOVE
    (#x05 ?\u1EB4) ;; CAPITAL LETTER A WITH BREVE AND TILDE
    (#x06 ?\u1EAA) ;; CAPITAL LETTER A WITH CIRCUMFLEX AND TILDE
    (#x14 ?\u1EF6) ;; CAPITAL LETTER Y WITH HOOK ABOVE
    (#x19 ?\u1EF8) ;; CAPITAL LETTER Y WITH TILDE
    (#x1E ?\u1EF4) ;; CAPITAL LETTER Y WITH DOT BELOW
    (#x80 ?\u1EA0) ;; CAPITAL LETTER A WITH DOT BELOW
    (#x81 ?\u1EAE) ;; CAPITAL LETTER A WITH BREVE AND ACUTE
    (#x82 ?\u1EB0) ;; CAPITAL LETTER A WITH BREVE AND GRAVE
    (#x83 ?\u1EB6) ;; CAPITAL LETTER A WITH BREVE AND DOT BELOW
    (#x84 ?\u1EA4) ;; CAPITAL LETTER A WITH CIRCUMFLEX AND ACUTE
    (#x85 ?\u1EA6) ;; CAPITAL LETTER A WITH CIRCUMFLEX AND GRAVE
    (#x86 ?\u1EA8) ;; CAPITAL LETTER A WITH CIRCUMFLEX AND HOOK ABOVE
    (#x87 ?\u1EAC) ;; CAPITAL LETTER A WITH CIRCUMFLEX AND DOT BELOW
    (#x88 ?\u1EBC) ;; CAPITAL LETTER E WITH TILDE
    (#x89 ?\u1EB8) ;; CAPITAL LETTER E WITH DOT BELOW
    (#x8A ?\u1EBE) ;; CAPITAL LETTER E WITH CIRCUMFLEX AND ACUTE
    (#x8B ?\u1EC0) ;; CAPITAL LETTER E WITH CIRCUMFLEX AND GRAVE
    (#x8C ?\u1EC2) ;; CAPITAL LETTER E WITH CIRCUMFLEX AND HOOK ABOVE
    (#x8D ?\u1EC4) ;; CAPITAL LETTER E WITH CIRCUMFLEX AND TILDE
    (#x8E ?\u1EC6) ;; CAPITAL LETTER E WITH CIRCUMFLEX AND DOT BELOW
    (#x8F ?\u1ED0) ;; CAPITAL LETTER O WITH CIRCUMFLEX AND ACUTE
    (#x90 ?\u1ED2) ;; CAPITAL LETTER O WITH CIRCUMFLEX AND GRAVE
    (#x91 ?\u1ED4) ;; CAPITAL LETTER O WITH CIRCUMFLEX AND HOOK ABOVE
    (#x92 ?\u1ED6) ;; CAPITAL LETTER O WITH CIRCUMFLEX AND TILDE
    (#x93 ?\u1ED8) ;; CAPITAL LETTER O WITH CIRCUMFLEX AND DOT BELOW
    (#x94 ?\u1EE2) ;; CAPITAL LETTER O WITH HORN AND DOT BELOW
    (#x95 ?\u1EDA) ;; CAPITAL LETTER O WITH HORN AND ACUTE
    (#x96 ?\u1EDC) ;; CAPITAL LETTER O WITH HORN AND GRAVE
    (#x97 ?\u1EDE) ;; CAPITAL LETTER O WITH HORN AND HOOK ABOVE
    (#x98 ?\u1ECA) ;; CAPITAL LETTER I WITH DOT BELOW
    (#x99 ?\u1ECE) ;; CAPITAL LETTER O WITH HOOK ABOVE
    (#x9A ?\u1ECC) ;; CAPITAL LETTER O WITH DOT BELOW
    (#x9B ?\u1EC8) ;; CAPITAL LETTER I WITH HOOK ABOVE
    (#x9C ?\u1EE6) ;; CAPITAL LETTER U WITH HOOK ABOVE
    (#x9D ?\u0168) ;; CAPITAL LETTER U WITH TILDE
    (#x9E ?\u1EE4) ;; CAPITAL LETTER U WITH DOT BELOW
    (#x9F ?\u1EF2) ;; CAPITAL LETTER Y WITH GRAVE
    (#xA0 ?\u00D5) ;; CAPITAL LETTER O WITH TILDE
    (#xA1 ?\u1EAF) ;; SMALL LETTER A WITH BREVE AND ACUTE
    (#xA2 ?\u1EB1) ;; SMALL LETTER A WITH BREVE AND GRAVE
    (#xA3 ?\u1EB7) ;; SMALL LETTER A WITH BREVE AND DOT BELOW
    (#xA4 ?\u1EA5) ;; SMALL LETTER A WITH CIRCUMFLEX AND ACUTE
    (#xA5 ?\u1EA7) ;; SMALL LETTER A WITH CIRCUMFLEX AND GRAVE
    (#xA6 ?\u1EA9) ;; SMALL LETTER A WITH CIRCUMFLEX AND HOOK ABOVE
    (#xA7 ?\u1EAD) ;; SMALL LETTER A WITH CIRCUMFLEX AND DOT BELOW
    (#xA8 ?\u1EBD) ;; SMALL LETTER E WITH TILDE
    (#xA9 ?\u1EB9) ;; SMALL LETTER E WITH DOT BELOW
    (#xAA ?\u1EBF) ;; SMALL LETTER E WITH CIRCUMFLEX AND ACUTE
    (#xAB ?\u1EC1) ;; SMALL LETTER E WITH CIRCUMFLEX AND GRAVE
    (#xAC ?\u1EC3) ;; SMALL LETTER E WITH CIRCUMFLEX AND HOOK ABOVE
    (#xAD ?\u1EC5) ;; SMALL LETTER E WITH CIRCUMFLEX AND TILDE
    (#xAE ?\u1EC7) ;; SMALL LETTER E WITH CIRCUMFLEX AND DOT BELOW
    (#xAF ?\u1ED1) ;; SMALL LETTER O WITH CIRCUMFLEX AND ACUTE
    (#xB0 ?\u1ED3) ;; SMALL LETTER O WITH CIRCUMFLEX AND GRAVE
    (#xB1 ?\u1ED5) ;; SMALL LETTER O WITH CIRCUMFLEX AND HOOK ABOVE
    (#xB2 ?\u1ED7) ;; SMALL LETTER O WITH CIRCUMFLEX AND TILDE
    (#xB3 ?\u1EE0) ;; CAPITAL LETTER O WITH HORN AND TILDE
    (#xB4 ?\u01A0) ;; CAPITAL LETTER O WITH HORN
    (#xB5 ?\u1ED9) ;; SMALL LETTER O WITH CIRCUMFLEX AND DOT BELOW
    (#xB6 ?\u1EDD) ;; SMALL LETTER O WITH HORN AND GRAVE
    (#xB7 ?\u1EDF) ;; SMALL LETTER O WITH HORN AND HOOK ABOVE
    (#xB8 ?\u1ECB) ;; SMALL LETTER I WITH DOT BELOW
    (#xB9 ?\u1EF0) ;; CAPITAL LETTER U WITH HORN AND DOT BELOW
    (#xBA ?\u1EE8) ;; CAPITAL LETTER U WITH HORN AND ACUTE
    (#xBB ?\u1EEA) ;; CAPITAL LETTER U WITH HORN AND GRAVE
    (#xBC ?\u1EEC) ;; CAPITAL LETTER U WITH HORN AND HOOK ABOVE
    (#xBD ?\u01A1) ;; SMALL LETTER O WITH HORN
    (#xBE ?\u1EDB) ;; SMALL LETTER O WITH HORN AND ACUTE
    (#xBF ?\u01AF) ;; CAPITAL LETTER U WITH HORN
    (#xC0 ?\u00C0) ;; CAPITAL LETTER A WITH GRAVE
    (#xC1 ?\u00C1) ;; CAPITAL LETTER A WITH ACUTE
    (#xC2 ?\u00C2) ;; CAPITAL LETTER A WITH CIRCUMFLEX
    (#xC3 ?\u00C3) ;; CAPITAL LETTER A WITH TILDE
    (#xC4 ?\u1EA2) ;; CAPITAL LETTER A WITH HOOK ABOVE
    (#xC5 ?\u0102) ;; CAPITAL LETTER A WITH BREVE
    (#xC6 ?\u1EB3) ;; SMALL LETTER A WITH BREVE AND HOOK ABOVE
    (#xC7 ?\u1EB5) ;; SMALL LETTER A WITH BREVE AND TILDE
    (#xC8 ?\u00C8) ;; CAPITAL LETTER E WITH GRAVE
    (#xC9 ?\u00C9) ;; CAPITAL LETTER E WITH ACUTE
    (#xCA ?\u00CA) ;; CAPITAL LETTER E WITH CIRCUMFLEX
    (#xCB ?\u1EBA) ;; CAPITAL LETTER E WITH HOOK ABOVE
    (#xCC ?\u00CC) ;; CAPITAL LETTER I WITH GRAVE
    (#xCD ?\u00CD) ;; CAPITAL LETTER I WITH ACUTE
    (#xCE ?\u0128) ;; CAPITAL LETTER I WITH TILDE
    (#xCF ?\u1EF3) ;; SMALL LETTER Y WITH GRAVE
    (#xD0 ?\u0110) ;; CAPITAL LETTER D WITH STROKE
    (#xD1 ?\u1EE9) ;; SMALL LETTER U WITH HORN AND ACUTE
    (#xD2 ?\u00D2) ;; CAPITAL LETTER O WITH GRAVE
    (#xD3 ?\u00D3) ;; CAPITAL LETTER O WITH ACUTE
    (#xD4 ?\u00D4) ;; CAPITAL LETTER O WITH CIRCUMFLEX
    (#xD5 ?\u1EA1) ;; SMALL LETTER A WITH DOT BELOW
    (#xD6 ?\u1EF7) ;; SMALL LETTER Y WITH HOOK ABOVE
    (#xD7 ?\u1EEB) ;; SMALL LETTER U WITH HORN AND GRAVE
    (#xD8 ?\u1EED) ;; SMALL LETTER U WITH HORN AND HOOK ABOVE
    (#xD9 ?\u00D9) ;; CAPITAL LETTER U WITH GRAVE
    (#xDA ?\u00DA) ;; CAPITAL LETTER U WITH ACUTE
    (#xDB ?\u1EF9) ;; SMALL LETTER Y WITH TILDE
    (#xDC ?\u1EF5) ;; SMALL LETTER Y WITH DOT BELOW
    (#xDD ?\u00DD) ;; CAPITAL LETTER Y WITH ACUTE
    (#xDE ?\u1EE1) ;; SMALL LETTER O WITH HORN AND TILDE
    (#xDF ?\u01B0) ;; SMALL LETTER U WITH HORN
    (#xE0 ?\u00E0) ;; SMALL LETTER A WITH GRAVE
    (#xE1 ?\u00E1) ;; SMALL LETTER A WITH ACUTE
    (#xE2 ?\u00E2) ;; SMALL LETTER A WITH CIRCUMFLEX
    (#xE3 ?\u00E3) ;; SMALL LETTER A WITH TILDE
    (#xE4 ?\u1EA3) ;; SMALL LETTER A WITH HOOK ABOVE
    (#xE5 ?\u0103) ;; SMALL LETTER A WITH BREVE
    (#xE6 ?\u1EEF) ;; SMALL LETTER U WITH HORN AND TILDE
    (#xE7 ?\u1EAB) ;; SMALL LETTER A WITH CIRCUMFLEX AND TILDE
    (#xE8 ?\u00E8) ;; SMALL LETTER E WITH GRAVE
    (#xE9 ?\u00E9) ;; SMALL LETTER E WITH ACUTE
    (#xEA ?\u00EA) ;; SMALL LETTER E WITH CIRCUMFLEX
    (#xEB ?\u1EBB) ;; SMALL LETTER E WITH HOOK ABOVE
    (#xEC ?\u00EC) ;; SMALL LETTER I WITH GRAVE
    (#xED ?\u00ED) ;; SMALL LETTER I WITH ACUTE
    (#xEE ?\u0129) ;; SMALL LETTER I WITH TILDE
    (#xEF ?\u1EC9) ;; SMALL LETTER I WITH HOOK ABOVE
    (#xF0 ?\u0111) ;; SMALL LETTER D WITH STROKE
    (#xF1 ?\u1EF1) ;; SMALL LETTER U WITH HORN AND DOT BELOW
    (#xF2 ?\u00F2) ;; SMALL LETTER O WITH GRAVE
    (#xF3 ?\u00F3) ;; SMALL LETTER O WITH ACUTE
    (#xF4 ?\u00F4) ;; SMALL LETTER O WITH CIRCUMFLEX
    (#xF5 ?\u00F5) ;; SMALL LETTER O WITH TILDE
    (#xF6 ?\u1ECF) ;; SMALL LETTER O WITH HOOK ABOVE
    (#xF7 ?\u1ECD) ;; SMALL LETTER O WITH DOT BELOW
    (#xF8 ?\u1EE5) ;; SMALL LETTER U WITH DOT BELOW
    (#xF9 ?\u00F9) ;; SMALL LETTER U WITH GRAVE
    (#xFA ?\u00FA) ;; SMALL LETTER U WITH ACUTE
    (#xFB ?\u0169) ;; SMALL LETTER U WITH TILDE
    (#xFC ?\u1EE7) ;; SMALL LETTER U WITH HOOK ABOVE
    (#xFD ?\u00FD) ;; SMALL LETTER Y WITH ACUTE
    (#xFE ?\u1EE3) ;; SMALL LETTER O WITH HORN AND DOT BELOW
    (#xFF ?\u1EEE)) ;; CAPITAL LETTER U WITH HORN AND TILDE
   mnemonic "VISCII"))

(set-language-info-alist
 "Vietnamese" '((charset vietnamese-viscii-lower vietnamese-viscii-upper)
		(coding-system viscii)
		(coding-priority viscii)
		(locale "vietnamese" "vi")
                ;; Not available in packages. 
		;; (input-method . "vietnamese-viqr")
		(features viet-util)
		(sample-text . "Vietnamese (Ti,1*(Bng Vi,1.(Bt)	Ch,1`(Bo b,1U(Bn")
		(documentation . "\
For Vietnamese, Emacs uses special charsets internally.
They can be decoded from and encoded to VISCC, VSCII, and VIQR.
Current setting put higher priority to the coding system VISCII than VSCII.
If you prefer VSCII, please do: (prefer-coding-system 'vietnamese-vscii)")
		))

;;; vietnamese.el ends here