(vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc) → (mv vardecls paramdecls imports typedefs)
Function:
(defun vl-sort-blockitems-aux (x vardecls-acc paramdecls-acc imports-acc typedefs-acc) (declare (xargs :guard (and (vl-blockitemlist-p x) (vl-vardecllist-p vardecls-acc) (vl-paramdecllist-p paramdecls-acc) (vl-importlist-p imports-acc) (vl-typedeflist-p typedefs-acc)))) (let ((__function__ 'vl-sort-blockitems-aux)) (declare (ignorable __function__)) (b* (((when (atom x)) (mv (rev (vl-vardecllist-fix vardecls-acc)) (rev (vl-paramdecllist-fix paramdecls-acc)) (rev (vl-importlist-fix imports-acc)) (rev (vl-typedeflist-fix typedefs-acc)))) (x1 (vl-blockitem-fix (car x))) ((mv vardecls-acc paramdecls-acc imports-acc typedefs-acc) (case (tag x1) (:vl-vardecl (mv (cons x1 vardecls-acc) paramdecls-acc imports-acc typedefs-acc)) (:vl-paramdecl (mv vardecls-acc (cons x1 paramdecls-acc) imports-acc typedefs-acc)) (:vl-import (mv vardecls-acc paramdecls-acc (cons x1 imports-acc) typedefs-acc)) (:vl-typedef (mv vardecls-acc paramdecls-acc imports-acc (cons x1 typedefs-acc))) (otherwise (mv vardecls-acc paramdecls-acc imports-acc typedefs-acc))))) (vl-sort-blockitems-aux (cdr x) vardecls-acc paramdecls-acc imports-acc typedefs-acc))))
Theorem:
(defthm vl-vardecllist-p-of-vl-sort-blockitems-aux.vardecls (b* (((mv ?vardecls ?paramdecls ?imports ?typedefs) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc))) (vl-vardecllist-p vardecls)) :rule-classes :rewrite)
Theorem:
(defthm vl-paramdecllist-p-of-vl-sort-blockitems-aux.paramdecls (b* (((mv ?vardecls ?paramdecls ?imports ?typedefs) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc))) (vl-paramdecllist-p paramdecls)) :rule-classes :rewrite)
Theorem:
(defthm vl-importlist-p-of-vl-sort-blockitems-aux.imports (b* (((mv ?vardecls ?paramdecls ?imports ?typedefs) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc))) (vl-importlist-p imports)) :rule-classes :rewrite)
Theorem:
(defthm vl-typedeflist-p-of-vl-sort-blockitems-aux.typedefs (b* (((mv ?vardecls ?paramdecls ?imports ?typedefs) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc))) (vl-typedeflist-p typedefs)) :rule-classes :rewrite)
Theorem:
(defthm vl-sort-blockitems-aux-of-vl-blockitemlist-fix-x (equal (vl-sort-blockitems-aux (vl-blockitemlist-fix x) vardecls-acc paramdecls-acc imports-acc typedefs-acc) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc)))
Theorem:
(defthm vl-sort-blockitems-aux-vl-blockitemlist-equiv-congruence-on-x (implies (vl-blockitemlist-equiv x x-equiv) (equal (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc) (vl-sort-blockitems-aux x-equiv vardecls-acc paramdecls-acc imports-acc typedefs-acc))) :rule-classes :congruence)
Theorem:
(defthm vl-sort-blockitems-aux-of-vl-vardecllist-fix-vardecls-acc (equal (vl-sort-blockitems-aux x (vl-vardecllist-fix vardecls-acc) paramdecls-acc imports-acc typedefs-acc) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc)))
Theorem:
(defthm vl-sort-blockitems-aux-vl-vardecllist-equiv-congruence-on-vardecls-acc (implies (vl-vardecllist-equiv vardecls-acc vardecls-acc-equiv) (equal (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc) (vl-sort-blockitems-aux x vardecls-acc-equiv paramdecls-acc imports-acc typedefs-acc))) :rule-classes :congruence)
Theorem:
(defthm vl-sort-blockitems-aux-of-vl-paramdecllist-fix-paramdecls-acc (equal (vl-sort-blockitems-aux x vardecls-acc (vl-paramdecllist-fix paramdecls-acc) imports-acc typedefs-acc) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc)))
Theorem:
(defthm vl-sort-blockitems-aux-vl-paramdecllist-equiv-congruence-on-paramdecls-acc (implies (vl-paramdecllist-equiv paramdecls-acc paramdecls-acc-equiv) (equal (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc-equiv imports-acc typedefs-acc))) :rule-classes :congruence)
Theorem:
(defthm vl-sort-blockitems-aux-of-vl-importlist-fix-imports-acc (equal (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc (vl-importlist-fix imports-acc) typedefs-acc) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc)))
Theorem:
(defthm vl-sort-blockitems-aux-vl-importlist-equiv-congruence-on-imports-acc (implies (vl-importlist-equiv imports-acc imports-acc-equiv) (equal (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc-equiv typedefs-acc))) :rule-classes :congruence)
Theorem:
(defthm vl-sort-blockitems-aux-of-vl-typedeflist-fix-typedefs-acc (equal (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc (vl-typedeflist-fix typedefs-acc)) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc)))
Theorem:
(defthm vl-sort-blockitems-aux-vl-typedeflist-equiv-congruence-on-typedefs-acc (implies (vl-typedeflist-equiv typedefs-acc typedefs-acc-equiv) (equal (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc) (vl-sort-blockitems-aux x vardecls-acc paramdecls-acc imports-acc typedefs-acc-equiv))) :rule-classes :congruence)