Function: multisession--create--cmacro

multisession--create--cmacro is a function defined in multisession.el.gz.

Signature

(multisession--create--cmacro CL-WHOLE &cl-quote &key KEY INITIAL-VALUE PACKAGE STORAGE SYNCHRONIZED CACHED-VALUE CACHED-SEQUENCE)

Documentation

compiler-macro for multisession--create.

Source Code

;; Defined in /usr/src/emacs/lisp/emacs-lisp/multisession.el.gz
;; Could not find source code, showing raw function object.
#[(cl-whole &rest --cl-rest--)
  ((let*
       ((key (car (cdr (plist-member --cl-rest-- ':key))))
	(initial-value
	 (car (cdr (plist-member --cl-rest-- ':initial-value))))
	(package (car (cdr (plist-member --cl-rest-- ':package))))
	(storage
	 (car
	  (cdr
	   (or (plist-member --cl-rest-- ':storage)
	       '(nil multisession-storage)))))
	(synchronized
	 (car (cdr (plist-member --cl-rest-- ':synchronized))))
	(cached-value
	 (car
	  (cdr
	   (or (plist-member --cl-rest-- ':cached-value)
	       '(nil multisession--unbound)))))
	(cached-sequence
	 (car
	  (cdr
	   (or (plist-member --cl-rest-- ':cached-sequence) '(nil 0))))))
     (progn
       (let ((--cl-keys-- --cl-rest--))
	 (while --cl-keys--
	   (cond
	    ((memq (car --cl-keys--)
		   '(:key :initial-value :package :storage
			  :synchronized :cached-value :cached-sequence
			  :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 (:key :initial-value :package :storage :synchronized :cached-value :cached-sequence)"
	      (car --cl-keys--))))))
       (cl-block multisession--create--cmacro
	 (cl--defsubst-expand
	  '(key initial-value package storage synchronized
		cached-value cached-sequence)
	  '(cl-block multisession--create
	     (record 'multisession key initial-value package storage
		     synchronized cached-value cached-sequence))
	  nil cl-whole nil key initial-value package storage
	  synchronized cached-value cached-sequence)))))
  (cl-struct-multisession-tags) nil
  "compiler-macro for `multisession--create'.\n\n(fn CL-WHOLE &cl-quote &key KEY INITIAL-VALUE PACKAGE STORAGE SYNCHRONIZED CACHED-VALUE CACHED-SEQUENCE)"]