Mercurial > hg > xemacs-beta
view lisp/symbol-syntax.el @ 2500:3d8143fc88e1
[xemacs-hg @ 2005-01-24 23:33:30 by ben]
get working with VC7
config.inc.samp: Declare OPTIONAL_LIBRARY_DIR as root of library directories.
Redo all graphics library defaults to mirror the versions and
directories in the current binary aux distribution on xemacs
web site. Enable TIFF and COMPFACE by default since you can
now compile with them and binary libs are provided.
xemacs.mak: Put our own directories first in case of conflict (e.g. config.h
in compface).
xemacs.mak: Use MSVCRT to avoid link problems.
s/windowsnt.h:
bytecode.c, print.c: Add casts to avoid warning.
compiler.h: Add MSC_VERSION and include definitions of DOESNT_RETURN and
friends here, like for GCC. Need different definitions for VC7
and VC6.
s/windowsnt.h: Remove stuff moved to compiler.h. Disable warning 4646 ("function
declared with __declspec(noreturn) has non-void return type")
on VC7 since lots of Lisp primitives trigger this and there is
no easy way to kludge around the warning.
glyphs-eimage.c: Some really nasty hacks to allow TIFF and JPEG to both be compiled.
#### The better solution is to move the TIFF and JPEG code to
different files.
glyphs-msw.c: Define __STDC__ to avoid problems with compface.h.
intl-auto-encap-win32.c, intl-auto-encap-win32.h, intl-encap-win32.c, syswindows.h: Those wankers at Microsoft cannot leave well enough alone.
Various functions change parameter types semi-randomly between
VC6 and VC7, so we need to include our own versions that
can handle both kinds with appropriate casting.
EmacsFrame.c, EmacsShell-sub.c, EmacsShell.c, alloc.c, alloca.c, buffer.c, bytecode.c, charset.h, chartab.c, cm.c, console-stream.c, console.c, data.c, debug.h, device-msw.c, device-tty.c, device-x.c, doprnt.c, dumper.c, dynarr.c, elhash.c, emacs.c, eval.c, event-Xt.c, event-gtk.c, event-msw.c, event-stream.c, events.c, extents.c, faces.c, file-coding.c, fileio.c, fns.c, font-lock.c, frame-gtk.c, frame-x.c, frame.c, free-hook.c, gccache-gtk.c, glyphs-eimage.c, glyphs-gtk.c, glyphs-msw.c, glyphs-x.c, glyphs.c, gtk-glue.c, gutter.c, input-method-xlib.c, insdel.c, intl-win32.c, keymap.c, lisp.h, lread.c, lstream.c, macros.c, malloc.c, menubar-gtk.c, menubar-msw.c, menubar-x.c, mule-coding.c, native-gtk-toolbar.c, number.c, objects-msw.c, objects.c, print.c, process-nt.c, process-unix.c, process.c, ralloc.c, rangetab.c, redisplay-gtk.c, redisplay-msw.c, redisplay-output.c, redisplay-tty.c, redisplay-x.c, redisplay.c, regex.c, scrollbar-gtk.c, scrollbar-x.c, search.c, select-x.c, signal.c, specifier.c, specifier.h, strftime.c, sunplay.c, symbols.c, sysdep.c, sysproc.h, text.c, text.h, toolbar-common.c, toolbar-msw.c, toolbar.c, ui-gtk.c, unexnt.c, unicode.c, win32.c, window.c, xgccache.c, s/windowsnt.h: abort() -> ABORT(). Eliminate preprocessor games with abort()
since it creates huge problems in VC7, solvable only by including
massive amounts of files in every compile (and not worth it).
author | ben |
---|---|
date | Mon, 24 Jan 2005 23:34:34 +0000 |
parents | 3ecd8885ac67 |
children | 308d34e9f07d |
line wrap: on
line source
;;; symbol-syntax.el --- find chars with symbol syntax ;; Copyright (C) 1992, 1993, 1997 Free Software Foundation, Inc. ;; Copyright (C) 1995 Sun Microsystems. ;; Author: JBW, JBW@_CORTEZ ;; Created: Wed Jun 20 15:15:34 1990 ;; Maintainer: XEmacs Development Team ;; Keywords: matching ;; 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: Not in FSF. ;;; Commentary: ;; Last modified by: Ben Wing, ben@xemacs.org ;; Last modified on: Mon Oct 2 02:32:05 GMT 1995 ;;; Code: (defvar symbol-syntax-table-alist nil) ;; '((c-mode-syntax-table) ;; (emacs-lisp-mode-syntax-table) ;; (lisp-mode-syntax-table) ;; (text-mode-syntax-table))) (defun update-symbol-syntax-table-alist () (let ((alist symbol-syntax-table-alist) item) (while (consp alist) (cond ((null (car alist)) (error "Missing alist item")) ((null (car (car alist))) (error "Alist item with null car")) ;; this functionality not used ((symbolp (setq item (car (car alist)))) (or (null (cdr (car alist))) (error "Alist item expected to have null cdr")) (while (symbolp item) (setq item (symbol-value item))) (setcar (car alist) item))) (cond ((not (syntax-table-p (car (car alist)))) (error "Alist item car expected to be symbol table")) ((null (cdr (car alist))) (setcdr (car alist) (make-symbol-syntax-table (car (car alist)))))) (setq alist (cdr alist))))) (defun get-symbol-syntax-table (norm-table) (let (result) (if (setq result (assq norm-table symbol-syntax-table-alist)) nil (update-symbol-syntax-table-alist) (if (setq result (assq norm-table symbol-syntax-table-alist)) nil (setq symbol-syntax-table-alist (cons (list norm-table) symbol-syntax-table-alist)) (update-symbol-syntax-table-alist) (or (setq result (assq norm-table symbol-syntax-table-alist)) (error "Syntax table missing from symbol-syntax-table-alist")))) (or (setq result (cdr result)) (error "Alist item has null cdr")) (or (syntax-table-p result) (error "Non-syntax-table item in alist")) result)) (defun make-symbol-syntax-table (in-table) (let ((out-table (copy-syntax-table in-table))) (map-syntax-table #'(lambda (key value) (if (eq ?_ (char-syntax-from-code value)) (put-char-table key (set-char-syntax-in-code value ?w) out-table)) nil) out-table) out-table)) ;; stuff for examining contents of syntax tables ;;(show-chars-with-syntax ;; '(c-mode-syntax-table ;; emacs-lisp-mode-syntax-table ;; lisp-mode-syntax-table ;; text-mode-syntax-table) ;; ?_) (defun show-chars-with-syntax (tables syntax) (let ((schars nil)) (unwind-protect (while (consp tables) (let* ((chars nil) (table-symbol (car tables)) (table table-symbol)) (or (symbolp table-symbol) (error "bad argument non-symbol")) (while (symbolp table) (setq table (symbol-value table))) (map-syntax-table #'(lambda (key value) (if (eq syntax (char-syntax-from-code value)) (setq chars (cons key chars))) nil) table) (setq schars (cons (list table-symbol (nreverse chars)) schars))) (setq tables (cdr tables)))) (nreverse schars))) (provide 'symbol-syntax) ;;; symbol-syntax.el ends here