Recognizer for vl-lucidocc structures.
(vl-lucidocc-p x) → *
Function:
(defun vl-lucidocc-p (x) (declare (xargs :guard t)) (let ((__function__ 'vl-lucidocc-p)) (declare (ignorable __function__)) (and (consp x) (cond ((or (atom x) (eq (car x) :solo)) (and (true-listp (cdr x)) (eql (len (cdr x)) 1) (b* ((ctx (std::da-nth 0 (cdr x)))) (vl-lucidctx-p ctx)))) ((eq (car x) :slice) (and (true-listp (cdr x)) (eql (len (cdr x)) 3) (b* ((left (std::da-nth 0 (cdr x))) (right (std::da-nth 1 (cdr x))) (ctx (std::da-nth 2 (cdr x)))) (and (vl-expr-p left) (vl-expr-p right) (vl-lucidctx-p ctx))))) (t (and (eq (car x) :tail) (and (true-listp (cdr x)) (eql (len (cdr x)) 1)) (b* ((ctx (std::da-nth 0 (cdr x)))) (vl-lucidctx-p ctx))))))))
Theorem:
(defthm consp-when-vl-lucidocc-p (implies (vl-lucidocc-p x) (consp x)) :rule-classes :compound-recognizer)