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)))))