(vl-genelementlist->vardecls x) → vardecls
Function:
(defun vl-genelementlist->vardecls (x) (declare (xargs :guard (vl-genelementlist-p x))) (let ((__function__ 'vl-genelementlist->vardecls)) (declare (ignorable __function__)) (b* (((when (atom x)) nil) (x1 (car x))) (vl-genelement-case x1 :vl-genbase (if (eq (tag x1.item) :vl-vardecl) (cons x1.item (vl-genelementlist->vardecls (cdr x))) (vl-genelementlist->vardecls (cdr x))) :otherwise (vl-genelementlist->vardecls (cdr x))))))
Theorem:
(defthm vl-vardecllist-p-of-vl-genelementlist->vardecls (b* ((vardecls (vl-genelementlist->vardecls x))) (vl-vardecllist-p vardecls)) :rule-classes :rewrite)
Theorem:
(defthm vl-sort-genelements-aux-is-vl-genelementlist->vardecls (equal (mv-nth 3 (vl-sort-genelements-aux x portdecls assigns aliases vardecls paramdecls fundecls taskdecls modinsts gateinsts alwayses initials finals typedefs imports fwdtypedefs modports genvars assertions cassertions properties sequences clkdecls gclkdecls defaultdisables dpiimports dpiexports binds classes covergroups elabtasks letdecls generates)) (append (rev (vl-vardecllist-fix vardecls)) (vl-genelementlist->vardecls x))))
Theorem:
(defthm vl-genelementlist->vardecls-of-vl-genelementlist-fix-x (equal (vl-genelementlist->vardecls (vl-genelementlist-fix x)) (vl-genelementlist->vardecls x)))
Theorem:
(defthm vl-genelementlist->vardecls-vl-genelementlist-equiv-congruence-on-x (implies (vl-genelementlist-equiv x x-equiv) (equal (vl-genelementlist->vardecls x) (vl-genelementlist->vardecls x-equiv))) :rule-classes :congruence)