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 make-ert-test.

Source Code

;; Defined in /usr/src/emacs/lisp/emacs-lisp/ert.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))))
	(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)))))
  (cl-struct-ert-test-tags) nil
  "compiler-macro for `make-ert-test'.\n\n(fn CL-WHOLE &cl-quote &key NAME DOCUMENTATION BODY MOST-RECENT-RESULT EXPECTED-RESULT-TYPE TAGS FILE-NAME)"]