Function: make-ert-test--cmacro

make-ert-test--cmacro is a function defined in ert.el.gz.

Signature

(make-ert-test--cmacro CL-WHOLE &cl-quote &key NAME DOCUMENTATION BODY MOST-RECENT-RESULT EXPECTED-RESULT-TYPE TAGS FILE-NAME)

Documentation

compiler-macro for inlining make-ert-test.

Source Code

;; Defined in /usr/src/emacs/lisp/emacs-lisp/ert.el.gz
;; Closure converted to defun by helpful.
(defun make-ert-test--cmacro
    (cl-whole &rest --cl-rest--)
  "compiler-macro for inlining `make-ert-test'.\n\n\\(fn CL-WHOLE &cl-quote &key NAME DOCUMENTATION BODY MOST-RECENT-RESULT EXPECTED-RESULT-TYPE TAGS FILE-NAME)"
  (let*
      ((name
	(car
	 (cdr
	  (plist-member --cl-rest-- ':name))))
       (documentation
	(car
	 (cdr
	  (plist-member --cl-rest-- ':documentation))))
       (body
	(car
	 (cdr
	  (or
	   (plist-member --cl-rest-- ':body)
	   '(nil
	     (cl-assert nil))))))
       (most-recent-result
	(car
	 (cdr
	  (plist-member --cl-rest-- ':most-recent-result))))
       (expected-result-type
	(car
	 (cdr
	  (or
	   (plist-member --cl-rest-- ':expected-result-type)
	   '(nil ':passed)))))
       (tags
	(car
	 (cdr
	  (or
	   (plist-member --cl-rest-- ':tags)
	   '(nil 'nil)))))
       (file-name
	(car
	 (cdr
	  (plist-member --cl-rest-- ':file-name)))))
    (progn
      (let
	  ((--cl-keys-- --cl-rest--))
	(while --cl-keys--
	  (cond
	   ((memq
	     (car --cl-keys--)
	     '(:name :documentation :body :most-recent-result :expected-result-type :tags :file-name :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 :documentation :body :most-recent-result :expected-result-type :tags :file-name)"
		   (car --cl-keys--))))))
      (cl-block make-ert-test--cmacro
	(cl--defsubst-expand
	 '(name documentation body most-recent-result expected-result-type tags file-name)
	 '(cl-block make-ert-test
	    (record 'ert-test name documentation body most-recent-result expected-result-type tags file-name))
	 nil cl-whole nil name documentation body most-recent-result expected-result-type tags file-name)))))