Function: make-comp-func--cmacro
make-comp-func--cmacro is a function defined in comp.el.gz.
Signature
(make-comp-func--cmacro CL-WHOLE &cl-quote &key NAME C-NAME BYTE-FUNC DOC INT-SPEC COMMAND-MODES LAP SSA-STATUS FRAME-SIZE VFRAME-SIZE BLOCKS LAP-BLOCK EDGES-H BLOCK-CNT-GEN EDGE-CNT-GEN HAS-NON-LOCAL SPEED PURE TYPE)
Documentation
compiler-macro for inlining make-comp-func.
Source Code
;; Defined in /usr/src/emacs/lisp/emacs-lisp/comp.el.gz
;; Closure converted to defun by helpful.
(defun make-comp-func--cmacro
(cl-whole &rest --cl-rest--)
"compiler-macro for inlining `make-comp-func'.\n\n\\(fn CL-WHOLE &cl-quote &key NAME C-NAME BYTE-FUNC DOC INT-SPEC COMMAND-MODES LAP SSA-STATUS FRAME-SIZE VFRAME-SIZE BLOCKS LAP-BLOCK EDGES-H BLOCK-CNT-GEN EDGE-CNT-GEN HAS-NON-LOCAL SPEED PURE TYPE)"
(let*
((name
(car
(cdr
(plist-member --cl-rest-- ':name))))
(c-name
(car
(cdr
(plist-member --cl-rest-- ':c-name))))
(byte-func
(car
(cdr
(plist-member --cl-rest-- ':byte-func))))
(doc
(car
(cdr
(plist-member --cl-rest-- ':doc))))
(int-spec
(car
(cdr
(plist-member --cl-rest-- ':int-spec))))
(command-modes
(car
(cdr
(plist-member --cl-rest-- ':command-modes))))
(lap
(car
(cdr
(plist-member --cl-rest-- ':lap))))
(ssa-status
(car
(cdr
(plist-member --cl-rest-- ':ssa-status))))
(frame-size
(car
(cdr
(plist-member --cl-rest-- ':frame-size))))
(vframe-size
(car
(cdr
(or
(plist-member --cl-rest-- ':vframe-size)
'(nil 0)))))
(blocks
(car
(cdr
(or
(plist-member --cl-rest-- ':blocks)
'(nil
(make-hash-table :test #'eq))))))
(lap-block
(car
(cdr
(or
(plist-member --cl-rest-- ':lap-block)
'(nil
(make-hash-table :test #'equal))))))
(edges-h
(car
(cdr
(or
(plist-member --cl-rest-- ':edges-h)
'(nil
(make-hash-table))))))
(block-cnt-gen
(car
(cdr
(or
(plist-member --cl-rest-- ':block-cnt-gen)
'(nil
(funcall #'comp-gen-counter))))))
(edge-cnt-gen
(car
(cdr
(or
(plist-member --cl-rest-- ':edge-cnt-gen)
'(nil
(funcall #'comp-gen-counter))))))
(has-non-local
(car
(cdr
(plist-member --cl-rest-- ':has-non-local))))
(speed
(car
(cdr
(plist-member --cl-rest-- ':speed))))
(pure
(car
(cdr
(plist-member --cl-rest-- ':pure))))
(type
(car
(cdr
(plist-member --cl-rest-- ':type)))))
(progn
(let
((--cl-keys-- --cl-rest--))
(while --cl-keys--
(cond
((memq
(car --cl-keys--)
'(:name :c-name :byte-func :doc :int-spec :command-modes :lap :ssa-status :frame-size :vframe-size :blocks :lap-block :edges-h :block-cnt-gen :edge-cnt-gen :has-non-local :speed :pure :type :allow-other-keys))
(unless
(cdr --cl-keys--)
(error "Missing argument for %s"
(car --cl-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 :c-name :byte-func :doc :int-spec :command-modes :lap :ssa-status :frame-size :vframe-size :blocks :lap-block :edges-h :block-cnt-gen :edge-cnt-gen :has-non-local :speed :pure :type)"
(car --cl-keys--))))))
(cl-block make-comp-func--cmacro
(cl--defsubst-expand
'(name c-name byte-func doc int-spec command-modes lap ssa-status frame-size vframe-size blocks lap-block edges-h block-cnt-gen edge-cnt-gen has-non-local speed pure type)
'(cl-block make-comp-func
(record 'comp-func name c-name byte-func doc int-spec command-modes lap ssa-status frame-size vframe-size blocks lap-block edges-h block-cnt-gen edge-cnt-gen has-non-local speed pure type))
nil cl-whole nil name c-name byte-func doc int-spec command-modes lap ssa-status frame-size vframe-size blocks lap-block edges-h block-cnt-gen edge-cnt-gen has-non-local speed pure type)))))