Function: make-js--pitem--cmacro

make-js--pitem--cmacro is a function defined in js.el.gz.

Signature

(make-js--pitem--cmacro CL-WHOLE &cl-quote &key CHILDREN PAREN-DEPTH TYPE H-BEGIN NAME B-END)

Documentation

compiler-macro for make-js--pitem.

Source Code

;; Defined in /usr/src/emacs/lisp/progmodes/js.el.gz
;; Could not find source code, showing raw function object.
#[(cl-whole &rest --cl-rest--)
  ((let*
       ((children (car (cdr (plist-member --cl-rest-- ':children))))
	(paren-depth
	 (car (cdr (plist-member --cl-rest-- ':paren-depth))))
	(type (car (cdr (plist-member --cl-rest-- ':type))))
	(h-begin (car (cdr (plist-member --cl-rest-- ':h-begin))))
	(name (car (cdr (plist-member --cl-rest-- ':name))))
	(b-end (car (cdr (plist-member --cl-rest-- ':b-end)))))
     (progn
       (let ((--cl-keys-- --cl-rest--))
	 (while --cl-keys--
	   (cond
	    ((memq (car --cl-keys--)
		   '(:children :paren-depth :type :h-begin :name
			       :b-end :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 (:children :paren-depth :type :h-begin :name :b-end)"
	      (car --cl-keys--))))))
       (cl-block make-js--pitem--cmacro
	 (cl--defsubst-expand
	  '(children paren-depth type h-begin name b-end)
	  '(cl-block make-js--pitem
	     (list children paren-depth type h-begin name b-end))
	  nil cl-whole nil children paren-depth type h-begin name
	  b-end)))))
  (cl-struct-js--pitem-tags) nil
  "compiler-macro for `make-js--pitem'.\n\n(fn CL-WHOLE &cl-quote &key CHILDREN PAREN-DEPTH TYPE H-BEGIN NAME B-END)"]