Function: elisp-scope-cl-lambda-optional
elisp-scope-cl-lambda-optional is a byte-compiled function defined in
elisp-scope.el.gz.
Signature
(elisp-scope-cl-lambda-optional ARG ARGLIST MORE BODY)
Source Code
;; Defined in /usr/src/emacs/lisp/emacs-lisp/elisp-scope.el.gz
(defun elisp-scope-cl-lambda-optional (arg arglist more body)
(let* ((a (ensure-list arg))
(var (car a))
(l elisp-scope-local-bindings)
(init (cadr a))
(svar (caddr a)))
(elisp-scope-1 init)
(if (consp var)
(let ((elisp-scope-local-bindings l))
(elisp-scope-cl-lambda-1 var (cons (append (when svar (list svar))
(cons '&optional arglist))
more)
body))
(when-let* ((bare (elisp-scope--sym-bare svar)))
(when-let* ((beg (elisp-scope--sym-pos svar)))
(elisp-scope--binding bare beg))
(setq l (elisp-scope--local-new bare (elisp-scope--sym-pos svar) l)))
(when-let* ((bare (elisp-scope--sym-bare var)))
(when-let* ((beg (elisp-scope--sym-pos var)))
(elisp-scope--binding bare beg))
(setq l (elisp-scope--local-new bare (elisp-scope--sym-pos var) l)))
(cond
(arglist
(let ((head (car arglist)))
(if-let* ((bare (elisp-scope--sym-bare head))
((memq bare '(&rest &body &key &aux))))
(progn
(when-let* ((beg (elisp-scope--sym-pos head)))
(elisp-scope--report 'ampersand beg bare))
(cl-case bare
((&rest &body)
(let ((elisp-scope-local-bindings l))
(elisp-scope-cl-lambda-rest (cadr arglist) (cddr arglist) more body)))
(&key (let ((elisp-scope-local-bindings l))
(elisp-scope-cl-lambda-key (cadr arglist) (cddr arglist) more body)))
(&aux (let ((elisp-scope-local-bindings l))
(elisp-scope-cl-lambda-aux (cadr arglist) (cddr arglist) more body)))))
(let ((elisp-scope-local-bindings l))
(elisp-scope-cl-lambda-optional head (cdr arglist) more body)))))
(more
(let ((elisp-scope-local-bindings l))
(elisp-scope-cl-lambda-1 (car more) (cdr more) body)))
(t (let ((elisp-scope-local-bindings l)) (elisp-scope-lambda nil body)))))))