Mercurial > hg > xemacs
view shared/repl-comment.el @ 0:107d592c5f4a
DICE versions, used by pers/common, recursive, I think/hope
author | Henry S. Thompson <ht@inf.ed.ac.uk> |
---|---|
date | Mon, 08 Feb 2021 11:44:37 +0000 |
parents | |
children |
line wrap: on
line source
;; Universal (?) replace comment in function ;; Last edited: Thu Oct 7 09:39:50 1993 (defun repl-comment (fn comment) "replace/install as FN's comment COMMENT, no matter what emacs/compiler" (let ((defn (symbol-function fn))) (if (consp defn) (if (eq (car defn) 'autoload) (progn (load-library (car (cdr defn))) (if (equal defn (symbol-function fn)) (error "autoloading didn't help define %s" fn) (repl-comment fn comment))) ;; either symbolic or old byte-compiler (if (eq (car defn) 'lambda) (if (stringp (car (cdr (cdr defn)))) (rplaca (cdr (cdr defn)) comment) (rplacd (cdr defn) (cons comment (cdr (cdr defn))))) (error "can't diagnose defn %s" defn))) ;; array or not (if (compiled-function-p defn) (fset fn (if (fboundp 'compiled-function-arglist) (progn (make-byte-code (compiled-function-arglist defn) (compiled-function-instructions defn) (compiled-function-constants defn) (compiled-function-stack-depth defn) comment (compiled-function-interactive defn)) defn) (repl-byte fn (list (cons 4 comment))))) (error "unrecognised defn %s" defn))))) (defun repl-byte (fn alist) "compute a new byte-code defn for FN, replacing elements using ALIST, which is interpreted as (index . newbit). Elements are 0: arglist 1: byte-codes 2: symbols 3: stack-depth 4: comment" (let ((defn (symbol-function fn))) (let ((ln (if (sequencep defn) (length defn) ;; hack otherwise 6)) (i 0) new entry) (apply (function make-byte-code) (progn (while (< i ln) (setq new (cons (if (setq entry (assoc i alist)) (cdr entry) (aref defn i)) new)) (setq i (1+ i))) (nreverse new)))))) (provide 'repl-comment)