Function: package-desc-create--cmacro

package-desc-create--cmacro is a function defined in package.el.gz.

Signature

(package-desc-create--cmacro CL-WHOLE &cl-quote &key NAME VERSION SUMMARY REQS KIND ARCHIVE DIR EXTRAS SIGNED)

Documentation

compiler-macro for package-desc-create.

Source Code

;; Defined in /usr/src/emacs/lisp/emacs-lisp/package.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))))
	(version (car (cdr (plist-member --cl-rest-- ':version))))
	(summary
	 (car
	  (cdr
	   (or (plist-member --cl-rest-- ':summary)
	       '(nil package--default-summary)))))
	(reqs (car (cdr (plist-member --cl-rest-- ':reqs))))
	(kind (car (cdr (plist-member --cl-rest-- ':kind))))
	(archive (car (cdr (plist-member --cl-rest-- ':archive))))
	(dir (car (cdr (plist-member --cl-rest-- ':dir))))
	(extras (car (cdr (plist-member --cl-rest-- ':extras))))
	(signed (car (cdr (plist-member --cl-rest-- ':signed)))))
     (progn
       (let ((--cl-keys-- --cl-rest--))
	 (while --cl-keys--
	   (cond
	    ((memq (car --cl-keys--)
		   '(:name :version :summary :reqs :kind :archive :dir
			   :extras :signed :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 :version :summary :reqs :kind :archive :dir :extras :signed)"
	      (car --cl-keys--))))))
       (cl-block package-desc-create--cmacro
	 (cl--defsubst-expand
	  '(name version summary reqs kind archive dir extras signed)
	  '(cl-block package-desc-create
	     (record 'package-desc name version summary reqs kind
		     archive dir extras signed))
	  nil cl-whole nil name version summary reqs kind archive dir
	  extras signed)))))
  (cl-struct-package-desc-tags) nil
  "compiler-macro for `package-desc-create'.\n\n(fn CL-WHOLE &cl-quote &key NAME VERSION SUMMARY REQS KIND ARCHIVE DIR EXTRAS SIGNED)"]