Mercurial > hg > xemacs-beta
view lisp/site-load.el @ 5070:b0f4adffca7d
fix so that CL docstrings (with &key, etc.) handled properly
-------------------- ChangeLog entries follow: --------------------
lisp/ChangeLog addition:
2010-02-23 Ben Wing <ben@xemacs.org>
* autoload.el:
* autoload.el (make-autoload):
* cl-macs.el (cl-function-arglist):
* cl-macs.el (cl-transform-lambda):
Don't add argument list with the tag "Common Lisp lambda list:";
instead add in "standard" form using "arguments:" and omitting the
function name. Add an arg to `cl-function-arglist' to omit the
name and use it in autoload.el instead of just hacking it off.
* help.el:
* help.el (function-arglist):
* help.el (function-documentation-1): New.
Extract out common code to recognize and/or strip the arglist from
documentation into `function-documentation-1'. Use in
`function-arglist' and `function-documentation'. Modify
`function-arglist' so it looks for the `arguments: ' stuff in all
doc strings, not just subrs/autoloads, so that CL functions get
recognized properly. Change the regexp used to match "arguments: "
specs to allow nested parens inside the arg list (happens when you
have a default value specified in a CL arglist).
author | Ben Wing <ben@xemacs.org> |
---|---|
date | Tue, 23 Feb 2010 01:12:13 -0600 |
parents | 3ecd8885ac67 |
children | e6508b64ee08 91b3aa59f49b |
line wrap: on
line source
;;; site-load.el --- Template file for site-wide XEmacs customization ;; Copyright (C) 1997 Free Software Foundation, Inc. ;; Author: Steven L. Baur <steve@xemacs.org> ;; Keywords: internal ;; This file is part of XEmacs. ;;; Commentary: ;; This is a prototype site-load.el file. ;; The site-load.el mechanism is provided so XEmacs installers can easily ;; dump lisp packages with XEmacs that do not get dumped standardly. ;; The file `site-packages' if it exists should look something like: ;; (setq site-load-packages '( ;; "../lisp/modes/cc-mode.elc" ;; "../lisp/utils/redo.elc" ;; "../lisp/packages/scroll-in-place.elc" ;; ) ;; ) ;; The first line and the last line must be exact. Each of the packages ;; listed must be double quoted, have either an absolute path, or a relative ;; to the build src directory path *and* be bytecompiled prior to the attempt ;; to dump. They also must explicitly have the .elc extension. ;; Because this is a trial implementation and the file is shared with ;; make-docfiles, syntax is strict and unforgiving. So sue me. It ;; is still better than the way it used to be. ;; Also note that site-packages belongs in the top level directory not the ;; lisp directory for use with --srcdir configurations. ;;; Code: (defvar site-load-package-file "../site-packages" "File name containing the list of extra packages to dump with XEmacs.") (defvar site-load-packages nil "A list of .elc files that should be dumped with XEmacs. This variable should be set by `site-load-package-file'.") ;; Load site specific packages for dumping with the XEmacs binary. (when (file-exists-p site-load-package-file) (let ((file)) (load site-load-package-file t t t) ;; The `pureload' macro is provided as a clue that a package is ;; being loaded in preparation of being dumped into XEmacs. (defmacro pureload (file) (list 'prog1 (list 'load file) '(garbage-collect))) (message "Loading site-wide packages for dumping...") (while site-load-packages (setq file (car site-load-packages)) (pureload file) (setq site-load-packages (cdr site-load-packages))) (message "Loading site-wide packages for dumping...done") (fmakunbound 'pureload))) ;; This file is intended for end user additions. ;; Put other initialization here, like setting of language-environment, etc. ;; Perhaps this should really be in the site-init.el. ;;; site-load.el ends here