(vl-modinstlist->instnames-nrev x nrev) → nrev
Function:
(defun vl-modinstlist->instnames-nrev (x nrev) (declare (xargs :stobjs (nrev))) (declare (xargs :guard (vl-modinstlist-p x))) (let ((__function__ 'vl-modinstlist->instnames-nrev)) (declare (ignorable __function__)) (b* (((when (atom x)) (nrev-fix nrev)) (name (vl-modinst->instname (car x))) (nrev (if name (nrev-push name nrev) nrev))) (vl-modinstlist->instnames-nrev (cdr x) nrev))))
Theorem:
(defthm vl-modinstlist->instnames-nrev-of-vl-modinstlist-fix-x (equal (vl-modinstlist->instnames-nrev (vl-modinstlist-fix x) nrev) (vl-modinstlist->instnames-nrev x nrev)))
Theorem:
(defthm vl-modinstlist->instnames-nrev-vl-modinstlist-equiv-congruence-on-x (implies (vl-modinstlist-equiv x x-equiv) (equal (vl-modinstlist->instnames-nrev x nrev) (vl-modinstlist->instnames-nrev x-equiv nrev))) :rule-classes :congruence)