Mercurial > hg > xemacs-beta
view lisp/post-gc.el @ 4989:d2ec55325515
make utf-8 default for Cygwin 1.7, rewrite init code determining default coding systems
-------------------- ChangeLog entries follow: --------------------
lisp/ChangeLog addition:
2010-02-06 Ben Wing <ben@xemacs.org>
* code-init.el:
* code-init.el (set-eol-detection):
* code-init.el (coding-system-current-system-configuration):
* code-init.el (coding-system-default-configuration-table): New.
* code-init.el (no-mule-no-eol-detection):
* code-init.el (define-coding-system-default-configuration): New.
* code-init.el (coding-system-variable-default-value-table): Removed.
* code-init.el (no-mule-eol-detection):
* code-init.el (coding-system-default-configuration-list): Removed.
* code-init.el (coding-system-default-variable-list):
* code-init.el (get-coding-system-variable):
* code-init.el (set-coding-system-variable):
* code-init.el (coding-system-variable-default-value):
* code-init.el (reset-coding-categories-to-default):
Significant clean-up, add Cygwin-UTF-8 support.
1. Shorten the names of the coding system variables to follow
what used to be considered the "abbreviations":
default-process-coding-system-read -> process-read
default-process-coding-system-write -> process-write
buffer-file-coding-system-for-read -> bfcs-for-read
default-buffer-file-coding-system -> default-bfcs
no-conversion-coding-system-mapping -> no-conv-cs
2. Instead of listing all the defaults in a big, strangely organized
table, use a new function
`define-coding-system-default-configuration' to define a
particular configuration. This uses a hash table stored in
`coding-system-default-configuration-table'. Rewrite
`coding-system-variable-default-value' appropriately.
3. Rename configurations to eliminate `unix' from the name:
unix-no-mule-no-eol-detection -> no-mule-no-eol-detection
unix-no-mule-eol-detection -> no-mule-eol-detection
unix-mule -> mule
This is because these are really for all systems but Windows,
not just Unix.
4. Add configuration `cygwin-utf-8', enabled when (featurep
'cygwin-use-utf-8). Uses `utf-8' for all defaults except for
`bfcs-for-read', which is `undecided'.
author | Ben Wing <ben@xemacs.org> |
---|---|
date | Sat, 06 Feb 2010 03:59:18 -0600 |
parents | 75b8038f720e |
children | d27c1ee1943b 308d34e9f07d |
line wrap: on
line source
;;; post-gc.el --- post-gc actions ;; Copyright (C) 1985-1986, 1990, 1992-1997 Free Software Foundation, Inc. ;; Copyright (c) 1993, 1994 Sun Microsystems, Inc. ;; Copyright (C) 1995 Board of Trustees, University of Illinois ;; Author: Mike Sperber <mike@xemacs.org> ;; Maintainer: XEmacs Development Team ;; Keywords: internal, dumped ;; 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, 59 Temple Place - Suite 330, ;; Boston, MA 02111-1307, USA. ;;; Synched up with: Not in FSF. ;;; Commentary: ;; This file is dumped with XEmacs. ;; This file defines actions to happen after each GC to perform ;; additional cleanup, call finalizers, etc. (defun run-finalizers (alist) "Run the finalizers for all objects that have just become unreachable." (let ((info (assq 'finalize-list alist))) (if info (let ((finalize-list (cdr info))) (while finalize-list (funcall (cdr (car finalize-list)) (car (car finalize-list))) (setq finalize-list (cdr finalize-list))))))) (add-hook 'post-gc-hook 'run-finalizers) (defvar simple-finalizer-ephemerons '() "List of ephemerons for objects that have a finalizer attached..") (defun add-finalizer (object func) "Add FUNC as a finalizer for object OBJECT." (setq simple-finalizer-ephemerons (cons (make-ephemeron object object func) simple-finalizer-ephemerons))) (defun cleanup-simple-finalizers (alist) "Clean up `simple-finalizer-ephemerons'." ;; We have to do this by hand because DELETE-IF isn't defined yet. (let ((current simple-finalizer-ephemerons) (prev nil)) (while (not (null current)) (if (not (ephemeron-ref (car current))) (if (null prev) (setq simple-finalizer-ephemerons (cdr current)) (setcdr prev (cdr current))) (setq prev current)) (setq current (cdr current))))) (add-hook 'post-gc-hook 'cleanup-simple-finalizers)