(vl-genelementlist->classes x) → classes
Function:
(defun vl-genelementlist->classes (x) (declare (xargs :guard (vl-genelementlist-p x))) (let ((__function__ 'vl-genelementlist->classes)) (declare (ignorable __function__)) (b* (((when (atom x)) nil) (x1 (car x))) (vl-genelement-case x1 :vl-genbase (if (eq (tag x1.item) :vl-class) (cons x1.item (vl-genelementlist->classes (cdr x))) (vl-genelementlist->classes (cdr x))) :otherwise (vl-genelementlist->classes (cdr x))))))
Theorem:
(defthm vl-classlist-p-of-vl-genelementlist->classes (b* ((classes (vl-genelementlist->classes x))) (vl-classlist-p classes)) :rule-classes :rewrite)
Theorem:
(defthm vl-sort-genelements-aux-is-vl-genelementlist->classes (equal (mv-nth 27 (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-classlist-fix classes)) (vl-genelementlist->classes x))))
Theorem:
(defthm vl-genelementlist->classes-of-vl-genelementlist-fix-x (equal (vl-genelementlist->classes (vl-genelementlist-fix x)) (vl-genelementlist->classes x)))
Theorem:
(defthm vl-genelementlist->classes-vl-genelementlist-equiv-congruence-on-x (implies (vl-genelementlist-equiv x x-equiv) (equal (vl-genelementlist->classes x) (vl-genelementlist->classes x-equiv))) :rule-classes :congruence)