diff options
Diffstat (limited to 'lisp/emacs-lisp/disass.el')
| -rw-r--r-- | lisp/emacs-lisp/disass.el | 13 | 
1 files changed, 8 insertions, 5 deletions
| diff --git a/lisp/emacs-lisp/disass.el b/lisp/emacs-lisp/disass.el index 9f4cca91676..4fd10185c17 100644 --- a/lisp/emacs-lisp/disass.el +++ b/lisp/emacs-lisp/disass.el @@ -78,13 +78,14 @@ redefine OBJECT if it is a symbol."  	    obj (symbol-function obj)))      (if (subrp obj)  	(error "Can't disassemble #<subr %s>" name)) -    (if (and (listp obj) (eq (car obj) 'autoload)) -	(progn -	  (load (nth 1 obj)) -	  (setq obj (symbol-function name)))) +    (when (and (listp obj) (eq (car obj) 'autoload)) +      (load (nth 1 obj)) +      (setq obj (symbol-function name)))      (if (eq (car-safe obj) 'macro)	;handle macros  	(setq macro t  	      obj (cdr obj))) +    (when (and (listp obj) (eq (car obj) 'closure)) +      (error "Don't know how to compile an interpreted closure"))      (if (and (listp obj) (eq (car obj) 'byte-code))  	(setq obj (list 'lambda nil obj)))      (if (and (listp obj) (not (eq (car obj) 'lambda))) @@ -215,7 +216,9 @@ OBJ should be a call to BYTE-CODE generated by the byte compiler."  	  (cond ((memq op byte-goto-ops)  		 (insert (int-to-string (nth 1 arg))))  		((memq op '(byte-call byte-unbind -			    byte-listN byte-concatN byte-insertN)) +			    byte-listN byte-concatN byte-insertN +			    byte-stack-ref byte-stack-set byte-stack-set2 +			    byte-discardN byte-discardN-preserve-tos))  		 (insert (int-to-string arg)))  		((memq op '(byte-varref byte-varset byte-varbind))  		 (prin1 (car arg) (current-buffer))) | 
