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 SAFETY PURE DECLARED-TYPE TYPE)

Documentation

compiler-macro for make-comp-func.

Source Code

;; Defined in /usr/src/emacs/lisp/emacs-lisp/comp.el.gz
;; Could not find source code, showing raw function object.
#[(cl-whole &rest --cl-rest--)
  ((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))))
	(safety (car (cdr (plist-member --cl-rest-- ':safety))))
	(pure (car (cdr (plist-member --cl-rest-- ':pure))))
	(declared-type
	 (car (cdr (plist-member --cl-rest-- ':declared-type))))
	(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 :safety :pure :declared-type :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 :safety :pure :declared-type :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 safety pure declared-type 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
		     safety pure declared-type 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 safety pure declared-type type)))))
  (t) nil
  "compiler-macro for `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 SAFETY PURE DECLARED-TYPE TYPE)"]