Function: make-comp-block-lap--cmacro

make-comp-block-lap--cmacro is a function defined in comp.el.gz.

Signature

(make-comp-block-lap--cmacro CL-WHOLE &cl-quote &key NAME INSNS CLOSED IN-EDGES OUT-EDGES IDOM DF POST-NUM FINAL-FRAME SP ADDR NON-RET-INSN NO-RET)

Documentation

compiler-macro for inlining make-comp-block-lap.

Source Code

;; Defined in /usr/src/emacs/lisp/emacs-lisp/comp.el.gz
;; Closure converted to defun by helpful.
(defun make-comp-block-lap--cmacro
    (cl-whole &rest --cl-rest--)
  "compiler-macro for inlining `make-comp-block-lap'.\n\n\\(fn CL-WHOLE &cl-quote &key NAME INSNS CLOSED IN-EDGES OUT-EDGES IDOM DF POST-NUM FINAL-FRAME SP ADDR NON-RET-INSN NO-RET)"
  (let*
      ((name
	(car
	 (cdr
	  (plist-member --cl-rest-- ':name))))
       (insns
	(car
	 (cdr
	  (plist-member --cl-rest-- ':insns))))
       (closed
	(car
	 (cdr
	  (plist-member --cl-rest-- ':closed))))
       (in-edges
	(car
	 (cdr
	  (plist-member --cl-rest-- ':in-edges))))
       (out-edges
	(car
	 (cdr
	  (plist-member --cl-rest-- ':out-edges))))
       (idom
	(car
	 (cdr
	  (plist-member --cl-rest-- ':idom))))
       (df
	(car
	 (cdr
	  (or
	   (plist-member --cl-rest-- ':df)
	   '(nil
	     (make-hash-table))))))
       (post-num
	(car
	 (cdr
	  (plist-member --cl-rest-- ':post-num))))
       (final-frame
	(car
	 (cdr
	  (plist-member --cl-rest-- ':final-frame))))
       (sp
	(car
	 (cdr
	  (plist-member --cl-rest-- ':sp))))
       (addr
	(car
	 (cdr
	  (plist-member --cl-rest-- ':addr))))
       (non-ret-insn
	(car
	 (cdr
	  (plist-member --cl-rest-- ':non-ret-insn))))
       (no-ret
	(car
	 (cdr
	  (plist-member --cl-rest-- ':no-ret)))))
    (progn
      (let
	  ((--cl-keys-- --cl-rest--))
	(while --cl-keys--
	  (cond
	   ((memq
	     (car --cl-keys--)
	     '(:name :insns :closed :in-edges :out-edges :idom :df :post-num :final-frame :sp :addr :non-ret-insn :no-ret :allow-other-keys))
	    (setq --cl-keys--
		  (cdr
		   (cdr --cl-keys--))))
	   ((car
	     (cdr
	      (memq ':allow-other-keys --cl-rest--)))
	    (setq --cl-keys-- nil))
	   (t
	    (error "Keyword argument %s not one of (:name :insns :closed :in-edges :out-edges :idom :df :post-num :final-frame :sp :addr :non-ret-insn :no-ret)"
		   (car --cl-keys--))))))
      (cl-block make-comp-block-lap--cmacro
	(cl--defsubst-expand
	 '(name insns closed in-edges out-edges idom df post-num final-frame sp addr non-ret-insn no-ret)
	 '(cl-block make-comp-block-lap
	    (record 'comp-block-lap name insns closed in-edges out-edges idom df post-num final-frame sp addr non-ret-insn no-ret))
	 nil cl-whole nil name insns closed in-edges out-edges idom df post-num final-frame sp addr non-ret-insn no-ret)))))